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当今 世界 ,以 计算 机 技术 .通信 技术 和 控制 技术 为 代表 的 3C 技术 正 迅 猛 发 展 ,而 以 
Internet 为 代表 的 全 球 范围 内 信息 基础 设施 的 建设 成 就 ,标志 着 人 类 社会 已 进入 信息 时 代 。 
应 用 型 人 才 培 养 是 社会 发 展 和 高 等 教育 发 展 的 必然 要 求 , 经 济 社会 发 展 迫 切 需要 高 等 学 校 
培养 出 在 知识 .能 力 、 素 质 等 诸 方面 都 适应 社会 需要 的 不 同 层 次 的 应 用 型 人 才 , 以 满足 信息 
化 社会 建设 的 需求 。 实 施 高 等 教育 名 校 建设 工程 ,对 大 力 发 展 高 等 教育 ,指导 高 等 教育 特色 
发 展 , 全 面 提高 教育 质量 ,增强 高 等 教育 的 竞争 力 和 服务 经 济 社会 能 力 具 有 重大 意义 。 

罗伯特 。 加 涅 是 美国 教育 心理 学 家 ,加 涅 将 认 知 学 习 理 论 应 用 于 教学 过 程 ,加 涅 理论 中 
的 引出 作业 和 提供 反馈 是 一 种 教学 策略 。 从 “应 用 型 * 人 才 培 养 的 角度 来 说 ,学 生 的 实践 能 
力 提 升 是 一 个 重要 问题 ,需要 学 校 和 教师 采取 一 些 有 效 手段 来 增强 学 生 的 实践 能 力 ,树立 以 
学 生 为 本 的 观念 ,尊重 学 生 的 个 性 特点 ,因材施教 ,增加 学 生 对 于 课程 .专业 的 选择 空间 。 

本 套 教 材 ( 指 以 刘 启 明教 授 主编 的 教材 ) 是 我 们 多 年 来 进行 “应 用 型 人 才 培 养 教学 内 容 、 
课程 体系 改革 ?的 综合 成 果 。 实 施 教学 方式 ,教学 内 容 ,考核 机 制 的 全 面 改 革 ,在 培养 学 生 的 
信息 能 力 和 信息 素养 方面 具有 先导 作用 。 我 们 提出 的 课程 内 容 设置 方案 ,目的 是 推进 人 文 
与 自然 的 有 机 融合 ,适应 学 生 能 力 、 兴 趣 . 个 性 `. 人 格 全 面 发 展 的 需要 ,强化 学 生 的 实践 能 力 
和 创新 能 力 培 养 ,为 计算 机 课程 教学 内 容 .课程 体系 改革 ,设计 了 一 个 全 新 的 框架 。 

本 套 教 材 以 应 用 型 .技能 型 人 才 培 养 为 目标 ,以 重点 专业 建设 为 平台 ,围绕 着 教育 教学 
改革 、 创 新 人 才 培 养 、 提 高 人 才 培 养 质量 的 教育 发 展 理念 展开 。 每 部 教材 都 是 由 应 用 型 名 校 
计算 机 专业 课 教 师 或 者 计算 机 实验 教学 示范 中 心 专业 教师 编写 完成 的 。 

在 本 套 教材 的 编写 过 程 中 ,我 们 得 到 许多 专家 的 精心 指点 和 热情 帮助 。 教 育 部 计算 机 
科学 与 技术 教学 指导 委员 会 先后 三 次 在 我 校 召 开 计 算 机 课程 教学 研讨 会 ,清华 大 学 .北京 大 
学 ,中 国人 民 大 学 、 复 旦 大 学 ,浙江 大 学 、 南 京 大 学 、 中 国 科 学 技术 大 学 等 近 百 所 高 校 的 老师 
参加 。 专 家 学 者 对 本 套 教材 的 编写 提出 了 很 多 宝贵 意见 。 

本 套 教材 的 出 版 得 到 清华 大 学 出 版 社 的 大 力 支 持 , 正 是 他 们 精益 求 精 的 工作 , 才 使 这 一 
系统 工程 得 以 顺利 完成 ,并 得 到 高 度 评价 ,在 此 表示 于 心 感谢 。 


刘 启 明 
2015 年 1 月 
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随 着 互联 网 的 不 断 发 展 和 平台 的 多 样 化 , 越 来 越 多 的 Web 开发 技术 呈现 在 用 户 面前 ， 
也 是 由 于 互联 网 的 不 断 发 展 , 越 来 越 多 的 普通 用 户 进入 了 互联 网 的 范围 开始 了 网 络 生活 。 
而 人 们 使 用 的 互联 网 的 应 用 ,通常 情况 是 通过 一 些 Web 编程 语言 进行 实现 的 ,这 些 语言 
括 ASP. NET、JSP 和 PHP 等 。Web 开发 技术 的 不 断 完善 ,更 多 丰富 的 应 用 程序 也 随 之 诞 
生 ,ASP. NET 使 用 . NET 平台 进行 Web 应 用 程序 开发 有 着 先天 的 优势 ,开发 人 员 能 够 快 
速 地 使 用 ASP. NET 提供 的 控件 进行 复杂 的 应 用 程序 开发 。 

本 书 以 高 素质 应 用 型 .技能 型 人 才 培养 为 目标 ,以 重点 专业 建设 为 平台 ,围绕 着 不 断 深 
化 教育 教学 改革 、 创 新 人 才 培 养 模式 、 提 高 人 才 培 养 质量 .实现 高 等 教育 又 好 又 快 发 展 的 教 
育 理念 。 

本 书 全 面 介 绍 ASP. NET 技术 ,附带 大 量 的 实例 及 详细 的 注释 ,方便 初学 者 深入 学 习 。 
本 书 的 主要 特点 是 通过 将 一 些 固定 的 知识 进行 分 类 讲解 ,举一反三 ,通过 简单 的 实例 讲解 复 
杂 的 理论 知识 ,让 学 生 能 够 通过 案例 来 对 所 学 内 容 进 行 深 入 理解 。 再 一 个 特点 就 是 本 教程 
不 是 面面俱到 ,不 是 把 所 有 ASP. NET 的 知识 都 罗列 出 来 ,而 是 仅仅 讲述 人 们 在 做 项 目 中 
经 常 使 用 到 的 相应 知识 ,对 于 不 常用 的 知识 ,让 学 生 学 会 如 何 查找 即 可 。 

本 书 由 邓 芳 . 毕 忠 东 、` 刘 启明 担任 主编 , 件 德 昆 , 刘 晓 梅 , 程 立 倩 担任 副 主 编 , 王 作 鹏 教 
授 、 崔 玉 礼 教授 审阅 了 书稿 。 

本 书 既 可 作为 计算 机 专业 的 专业 课程 教材 ,也 可 以 作为 网 页 制作 爱好 者 、.ASP. NET 应 
用 程序 初学 者 、. NET 应 用 开发 入门 者 的 指导 书 。 

在 本 教材 的 编写 、 出 版 过 程 中 ,我 们 得 到 许多 专家 的 精心 指点 和 热情 帮助 。 清 华 大 学 出 
版 社 给 予 了 大 力 支持 , 正 是 他 们 精益 求 精 的 工作 , 才 使 这 一 系统 工程 得 以 顺利 完成 ,并 得 到 
高 度 评价 «TE Heo OD alit 

限于 作者 水 平 , 书 中 难免 存在 谬误 之 处 , 奶 请 广大 专家 、 读 者 提出 宝贵 意见 。 


作者 
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第 1 意 ASP. NET 8g] it 


本 章 要 点 

* ASP. NET 概述 , 

* ASP. NET 运行 原理 。 
* ASP. NET 网 站 建设 。 


1.1 ASP.NET 简介 


1.1.1 ASP. NET 发 展 历程 


ASP. NET 是 作为 . NET 框架 体系 结构 的 一 部 分 推出 的 。2000 年 ASP. NET 1.0 正式 
发 布 ,2003 年 ASP. NET 升级 为 1.1 版 本 。ASP. NET 1.1 发 布 之 后 更 加 激发 了 Web 应 用 
程序 开发 人 员 对 ASP. NET 的 兴趣 。 于 是 在 2005 年 11 月 微软 公司 又 发 布 了 ASP. NET 
2.0, ASP. NET 2. 0 的 发 布 是 . NET 技术 走向 成 熟 的 标志 。ASP. NET 2. 0 技术 增加 了 大 
量 方便 、 实 用 的 新 特性 ,是 一 种 建立 在 公共 语言 运行 库 上 的 编程 框架 ,可 用 于 在 服务 器 上 开 
发 功能 强大 的 Web 应 用 程序 。 它 不 但 执行 效率 大 幅度 提高 ,对 代码 的 控制 也 做 得 更 好 ,并 
且 支 持 Web Controls 功能 和 多 种 语言 ,以 高 安全 性 、 易 管理 性 和 高 扩展 性 等 特点 著称 。 

ASP. NET 技术 从 1.0 版 本 升级 到 1. 1 变化 不 是 很 大 。 从 ASP. NET 1. x 到 ASP. NET 
2.0, 却 发 生 相当 大 的 变化 ,在 开发 过 程 中 微软 公司 深入 市 场 ,针对 大 量 开 发 人 员 和 软件 使 用 
者 进行 了 卓有成效 的 研究 ,并 为 其 指定 了 开发 代号 ASP. NET Whidbey。ASP. NET 2.0 设 
计 目 标的 核心 可 以 用 一 个 词 “简化 ”来 形容 。 因 为 其 设计 目标 是 将 应 用 程序 代码 数 减 少 
70% ,改变 过 去 那 种 需要 编写 很 多 重复 性 代码 的 状况 , 尽 可 能 做 到 写 很 少 的 代码 就 能 完成 任 
务 。 对 于 应 用 构架 师 和 开发 人 员 而 言 ,可 以 说 ASP. NET 2. 0 是 Microsoft Web 开发 史上 
的 一 个 重要 的 里 程 碑 。 


1.1.2 ASP. NET 能 做 哪些 事情 


ASP. NET 作为 Web 设计 技术 的 一 种 , 它 的 主要 功能 是 产生 动态 网 页 ,以 满足 不 同 用 
户 的 需要 。 在 网 上 见得 最 多 的 是 HTML 页 面 (文件 的 后 组 名 为 . htm 或 . html), € REH 
别人 编辑 好 的 Web 页 面 展现 给 大 家 ,这 种 页 面 如 果 不 手 动 去 修改 ,是 不 会 发 生 任何 变化 的 。 
如 果 想 在 网 页 中 访问 数据 库 , 这 种 纯 HTML 页 面 就 无 能 为 力 了 。 这 时 就 得 依赖 各 种 Web 
ER. MRE ,论坛 等 都 是 由 这 些 技术 产生 的 。 

ASP. NET 作为 一 种 新 的 Web 技术 , 它 给 予 设 计 者 一 种 全 新 的 Web 设计 概念 。 它 将 
软件 设计 和 Web 设计 融 为 一 个 整体 。 由 于 它 和 VC. NET、VB. NET、VC# 这 些 程序 设计 
语言 使 用 同一 个 . NET Framework 对 象 开发 库 , 可 以 想象 ASP. NET 所 能 实现 的 功能 是 多 
么 强大 ,几乎 VC. NET 能 做 到 的 事情 ,ASP. NET 也 能 做 到 。 


1.1.3 ASP. NET 的 运行 原理 


当 一 个 HTTP 请 求 到 达 服 务 器 并 被 IIS 接收 到 之 后 ,IIS 首先 通过 客户 端 请 求 的 页 面 
类 型 为 其 加 载 相 应 的 dll 文件 ,然后 在 处 理 过 程 中 将 这 条 请 求 发 送 给 能 够 处 理 这 个 请 求 的 
模块 。 在 ASP. NET 2.0 中 ,这 个 模块 称 为 HttpHandler(HTTP 处 理 程序 组 件 ) ,之 所 以 
.aspx 这样 的 文件 可 以 被 服务 器 处 理 , 就 是 因为 在 服务 器 端 有 默认 的 HttpHandler 专门 处 
HE. aspx 文件 。IIS 再 将 这 条 请 求 发 送 给 能 够 处 理 这 个 请 求 的 模块 之 前 ,还 需要 经 过 一 些 
HttpModule 的 处 理 ,这些 都 是 系统 默认 的 Modules( 用 于 获取 当前 应 用 程序 的 模块 集合 )， 
在 这 个 HTTP 请 求 转 到 HttpHandler 之 前 要 经 过 不 同 的 HttpModuls 的 处 理 。 这 样 做 的 
好 处 ,一 是 为 了 一 些 必需 的 过 程 ,二 是 为 了 安全 性 ,三 是 为 了 提高 效率 ,四 是 为 了 用 户 能 够 在 
更 多 的 环节 上 进行 控制 ,增强 用 户 的 控制 能 力 。ASP. NET 2.0 的 运行 原理 如 图 1. 1 所 示 。 
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图 运行 原理 


CD 用 户 请 求 发 送 到 Web 服务 器 ; © 将 请 求 通过 相应 的 . dll 文件 发 送 到 ASP. NET 引擎 ， 
© 用 户 请 求 通过 HTTP B; © HTTP 处 理 模块 被 调用 ,并 返回 到 用 户 请 求 文件 


1.2 制作 一 个 ASP.NET 网 站 


1.2.1 创建 ASP.NET 网 站 


启动 Visual Studio 2005 开发 环境 后 ,首先 进入 “起 始 页 "界面, 执行“ 文件” 一“ 新建 ”一 
“网 站 ”命令 ,创建 一 个 ASP. NET 网 站 ,如 图 1.2 所 示 。 


图 新 建 网 站 


选择 创建 “网 站 ”后 ,在 打开 的 “新 建 网 站 ”窗口 中 ,选择 “ASP. NET. 网 站 ”, 并 输入 网 站 
的 位 置 , 单 击 “ 确 定 ” 按 钮 ,完成 test 网 站 的 创建 ,如 图 1. 3 所 示 。 


G ASP.NET Yeb 服务 豆 个 人 网 站 初学 者 工具 包 
RISE NET Crystal Reports Y... 


图 新 建 网 站 窗口 


此 时 会 进入 Visual Studio 2005 Web 页 设计 页 面 ,Web 窗 体 的 布局 如 图 1.4 所 示 。 


ww dc) Wo 
PED 


ORE EX ve fe) (5) (8 E 


ERI 


Defanlt. aspe Yeb XP 


Destefal 
文件 各 loft asp 


E Lut 9 -- ii El 


1.2.2 S AR 


创建 了 一 个 网 站 后 , 接 下 来 的 工作 就 是 设计 Web 页 面 。 一 个 Web 页 包含 两 部 分 :“ 设 
计 ” 视 图 和 “ 源 ” 视 图 。 在 “设计 ”视图 中 ,用 户 可 以 从 “工具 箱 ” 选 项 卡 中 直接 选择 各 种 控件 添 
加 到 Web 页 面 上 ,也 可 在 页 面 上 直接 输入 文字 。 
$3 


在 “ 源 ” 视 图 中 ,直接 写 和 人 代码 ,如 图 1.5 所 示 。 


Default. aspx EN] 
客户 菇 对 象 和 事件 - 


OB Page Linguage- CR" Autobventireupc true" CodeFile- Default aspx. cs” Inherits=" Default" KY 


<IDOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Trensitional//EN" "htt 
gi tnl. xmlns="http: /wre v3. org/1999/xhtal" > 

head runat="server"> 
1 <title) 网 站 Ytitle> 

head 


Dody? 
<form id=” fe 


orml" runat="server") 


iv» 
1 名) 我 的 第 一 个 网 站 9 </p> 


Qv? 


E 在 "UR" 视图 中 加 入 代码 


1.2.3 运行 应 用 程序 


Visual Studio 中 有 多 种 方法 运行 应 用 程序 。 可 以 执行 “调试 ”启动 调试 ”命令 运行 
应 用 程序 ,如 图 1.6 所 示 ; 也 可 以 单 击 工具 栏 上 的 “调试 ?按钮 运行 应 用 程序 ,如 图 1.7 所 示 ; 
还 可 以 直接 按 F5 键 运 行程 序 。 
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图 启动 “调试 ”菜单 运行 程序 
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图 通过 工具 栏 运行 应 用 程序 


如 果 是 第 一 次 运行 网 站 , 则 会 弹出 “未 启用 调试 ”对 话 框 ,如 图 1. 8 所 示 。 该 对 话 框 中 ， 
用 户 可 以 选择 添加 Web. config 文件 。 单 击 “ 确 定 ” 按 钮 ,就 可 以 将 Web. config 文件 添加 到 
Web 应 用 程序 中 ,并 启用 调试 功能 。 

最 后 运行 的 结果 如 图 1.9 所 示 。 

这 是 个 简单 的 例子 ,细心 的 读者 会 发 现 ,在 这 个 例子 中 除了 后 级 名 为 . aspx 的 文件 以 
外 ,根本 没有 用 到 一 个 属于 ASP. NET 的 特性 。 实 际 上 这 个 例子 的 程序 代码 就 只 是 纯 
HTML, 没 有 一 点 延伸 。 这 个 例子 反映 了 一 个 特性 , 那 就 是 任何 一 个 纯 HTML 文件 都 可 以 
改写 成 为 ASP. NET 程序 。 


1.3 小 结 


本 章 主要 介绍 ASP. NET 的 运行 原理 ,以 及 如 何在 Visual Studio 中 建立 网 站 。 


习 , 读 者 能 熟悉 Visual Studio 的 主要 界面 ,了 解 Visual Studio 的 运行 机 制 。 


课 后 思考 问题 


1. 如 何在 Web 应 用 中 再 添加 一 个 页 面 ? 
2. web. config 文件 能 否 在 Web 应 用 程序 中 新 建 ? 如 何 建立 ? 
3. web. config 文件 的 作用 是 什么 ? 


通过 
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第 2 章 ASP.NET 内 置 对 象 


本 章 要 点 
* 了 解 Response, Request, Server 对 象 的 用 法 。 
。 初步 了 解 ASP. NET 的 输入 输出 方法 。 


本 章 将 通过 介绍 ASP. NET 中 的 Response, Request, Server 这 3 个 常用 对 象 的 应 用 ， 
学 习 ASP. NET 处 理 动态 Web 页 面 的 一 般 方法 。 


2.1 Response 对 象 


Response 对 象 是 实际 在 执行 System. Web 命名 空间 中 的 类 HttpResponse。CLR 会 根 
据 用 户 的 请 求 信息 建立 一 个 Response 对 象 ,Response 将 用 于 回应 客户 浏览 器 ,告诉 浏览 器 
回应 内 容 的 报头 .服务 器 端的 状态 信息 以 及 输出 指定 的 内 容 。 

1. Response. Write( ) 方 法 

Write 方法 输出 指定 的 文本 内 容 。 例 如 


Response.Write ("欢迎 来 到 ASP.COM") ; 
Write 方法 还 可 以 输出 HTML 代码 ,以 字符 串 的 形式 输出 。 例 如 : 
Response.Write ("<a href= 'http://www.sina.com'> 新 浪 </a>"); 


2. Response. End() 方法 

End 方法 使 得 Web 服务 器 停止 当前 程序 的 处 理 并 返回 结果 。 剩 下 文件 内 容 是 没有 处 
理 的 。 这 个 方法 可 以 用 在 调试 过 程 中 使 用 。 

3. Response. RedirectCurD 方法 

Redirect 方法 会 让 页 面 自动 的 跳 转 到 url 所 指定 的 页 面 。 在 Default. aspx. cs 页 面 中 输 
入 如 下 代码 : 


protected void Page Load(object sender, EventArgs e) 
t 

Response.Redirect ("~ NNTansferTest.aspx"); 
} 


运行 Default. aspx 页 面 ,最 终 的 运行 结果 如 图 2. 1 所 示 。 


Bit 0) [E] http: //1ocalhost: 1230/mySite/TansferTest. aspx 


我 是 跳 转 页 面 TansferTest 


图 运行 结果 


2.2 Request 对 象 


Request 对 象 实际 上 操作 System. Web 命名 空间 中 的 类 HttpRequest。 当 客户 发 出 请 
求 执行 ASP. NET 程序 时 ,CLR 会 将 客户 端的 请 求 信 息 包装 在 Request 对 象 中 。 这 些 请 求 
信息 包括 请 求 报头 (Header) .请求 方 法 (如 POST .GET) ,参数 名 和 参数 值 等 。 

Request 对 象 的 调用 方法 如 下 : 


Request .Collection["Variable"] 


其 中 , Collection 包括 QueryString, Form, Cookies, ServerVariables 4 种 集合 。 这 里 的 
Collection 可 以 省 略 , 也 就 是 说 Request["Variable" ] 5j Request. Collection[ " Variable"] 这 
两 种 写法 都 是 允许 的 。 如 果 省 略 了 Collection, IRA Request 对 象 会 依照 QueryString、 
Form,Cookies,ServerVariables 的 顺序 查找 ,直至 发 现 Variable 所 指 的 关键 字 并 返回 其 值 ， 
如 果 没 有 发 现 其 值 ,方法 则 返回 空 值 (Null)。 

为 了 优化 程序 的 执行 效率 ,建议 最 好 还 是 使 用 Collection, 如 果 过 多 地 搜索 ,会 降低 程序 
的 执行 效率 。 


2.2.1 QueryString 集合 


QueryString 集合 收集 的 信息 来 自 于 请 求 URL 地 址 中 *?” 号 后 面 的 数据 ,这 些 数据 称 
HURL 附加 信息 ”: 


http://www.aspcn.com/show.asp?id-111 


在 此 URL rP , QueryString 收集 到 的 附加 信息 是 “show. asp?” 后 的 数据 id— 111. 

此 时 ,取得 参数 id 的 参数 值 的 语句 如 下 : 

Request .QueryString["id"] 

QueryString 主要 用 于 收集 HTTP 中 的 GET 请 求 发 送 的 数据 ,如 果 在 一 个 请 求 事件 中 
被 请 求 的 程序 URL 地 址 出 现 了 “?" 号 的 数据 , 则 表示 此 次 的 请 求 方式 为 GET。GET 方法 
是 HTTP 中 的 默认 请 求 方法 ,最 常用 的 超 链 接 , 便 是 GET 方法 发 送 请 求 。 

直接 在 URL 中 写 上 参数 与 参数 值 发 送 GET 请 求 : 

«a href ="show.aspx?id=111"> 显 示 ID 为 111 的 文章 < /a> 

这 样 就 可 以 在 show. aspx 页 面 通过 Request. QueryString[ "id"] 方 式 获 取 到 地 址 栏 中 
传 过 来 的 id 的 值 。 

也 可 以 通过 Form 来 发 送 GET 请 求 。 


< form action= "show.aspx" method= "get"> 


«input type="text" name="id" value- "111" 
«/ form» 
去 form> 标 签 中 的 method 并 没有 设置 ,因为 浏览 器 默认 的 发 送 方法 就 是 GET ,并 不 需 
要 明确 标明 ,当然 标明 了 也 不 会 出 错 。 
下 面 通过 两 个 实例 来 演示 使 用 Form 发 送 GET 请 求 。 演 示 将 使 用 两 个 名 为 login. 
xc E 


html 和 login. aspx 的 文件 。 
login. html 如 下 : 


«html» 
«head» 
<title> 登 录 页 面 < /title» 
< /head» 
<body> 
< form action- "login.aspx" post- "get"> 
用 户 名 : «input id- "username" name- "username" type- "text" /»«br /> 
密 &nbsp; 码 : «input id- "pwd" name- "pwd" type- "password" /»«br /> 
«input id- "Submitl" type="submit" value- "提交 " /> 
«input id- "Resetl" type- "reset" value- "ifi" /> 
</form> 
< /body> 
</htm> 


login. aspx 如 下 : 


<html> 

<head runat= "server"> 
<title> 接 受 cET 请求 < /title> 

</head> 

<body> 
<h2> 接 受 GET 请求 < /n2» 
<% 
string username =Request .QueryString ["username"] ; 
string pwd =Request .QueryString["pwd"] ; 
Response.Write (" 你 的 用 户 名 为 : " +username + "<br/> 9 687g : " +pwd); 
$> 

< /body> 

</html> 


运行 结果 如 图 2.2 和 图 2. 3 所 示 。 


发 送 GET 请 求 
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图 发 送 ”请 求 


GET 方法 会 将 传递 的 参数 与 参数 值 添加 到 URL 地 址 中 ,而 且 包含 附加 信息 的 URL 
地 址 均 会 显示 在 浏览 器 的 地 址 栏 中 。 
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接受 GET 请 求 


GET 提 交 地 址 栏 中 的 变化 


你 的 用 户 名 为 ，dd 
密码 为 ，123 


2.2.2 Form 集合 


GET 方 法 是 将 传递 的 数据 追加 至 URL 中 。URL 地 址 长 度 是 有 限制 的 ,因此 使 用 
GET 方法 所 能 传递 的 数据 也 是 有 限 。 一 般 地 ,GET 方法 能 够 传递 256B 的 数据 。 在 多 数 情 
况 下 ,GET 方法 传递 的 数据 长 度 是 远 远 不 够 的 。 这 时 便 需 要 使 用 HTTP 的 另外 一 种 请 求 
方式 POST. POST 方法 可 传递 的 数据 最 大 值 为 2MB。 

POST 请 求 必须 由 Form 发 出 ,例如 : 

< form action= "login.aspx" method- "post"> 

您 的 大 名 : «input type- "text" name- "username" /><br/> 
<input type= "submit" value=" 发 送 " /> 

«form» 

使 用 POST 请 求 时 ,二 form 二 标签 中 的 method 属性 值 设置 为 POST。 

ASP. NET 使 用 Request. Form 方法 接收 POST 方法 传递 的 数据 。 


Request.Form["variable"] 


下 面 通过 实例 来 演示 POST 提交 ,演示 将 使 用 两 个 名 为 login. html 和 login. aspx 的 文件 。 
login. html 如 下 : 


<html> 
<head> 
<title> 登 录 页 面 发 送 POST 请 求 < /title> 
< /head> 
<body> 


<h2> 发 送 POST 请 求 < /n2» 
< form action- "login.aspx" method- "post" 
用 户 名 : «input id- "username" name- "username" type="text" /» «br /> 
密 &nbsp; lij: «input id- "pwd" name- "pwd" type="password" /»«br /> 
«input id- "Submitl" type="submit" value- "提交 " /> 
«input id- "Resetl" type- "reset" value- "Hi 'É" /> 
«/form» 
< /body» 
</html> 


login. aspx 如 下 : 


«html» 

X head runat="server"> 
<title> 接 受 POST iK « /title» 

< /head» 

<body> 
<h2> 接 受 POST 请 求 < /h2» 
«8 
string username -Request.Form["username"]; 
string pwd - Request .Form["pwd"]; 
Response.Write (" 你 的 用 户 名 为 : " - username +"<br/> 密 码 为 : " e pwd) ; 
$> 

< /body> 

</html> 


运行 结果 如 图 2.4 和 图 2.5 所 示 。 
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接受 POST 请 求 — POST 请 求 地 址 栏 中 的 内 容 


你 的 用 户 名 为 ，dd 
密码 为 ，123 


图 接受 请 求 
从 图 2.4 可 以 看 出 ,通过 POST 方式 发 送 的 数据 将 不 会 显示 在 URL 中 ,因此 用 POST 
发 送 数据 会 比 GET 发 送 数据 安全 。 
2.3 Server 对 象 


Response 对 象 是 执行 System. Web 命名 空间 中 的 类 HttpServerUtility。Server 对 象 
提供 许多 访问 的 方法 和 属性 帮助 程序 有 序 地 执行 。 
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1. Server. MapPath() 方法 
Server. MapPath 方法 将 虚拟 路 径 转 换 为 绝对 路 径 。 例 如 在 . cs 页 面 中 输入 以 下 代码 : 


Response.Write (Server.MapPath ("~ \\")); 


会 在 屏幕 上 输出 当前 网 站 的 绝对 路 径 D:\mySite\。 此 绝对 路 径 就 是 当前 网 站 的 根 目 录 , 就 
是 解决 方案 中 显示 的 根 目录 ,如 图 2.6 所 示 。 

2. Server. Transfer(path) 方 法 

终止 当前 程序 的 执行 ,自动 跳 转 到 path 所 指 的 页 面 。 在 Default. aspx. cs 页 面 中 输入 
如 下 代码 : 

protected void Page Load(object sender, EventArgs e) 

{ 


Server.Transfer ("~ \\TansferTest .aspx"); 
) 


运行 后 结果 如 图 2.7 所 示 。 


FYTYSEEEXCTIN 


O D: VeySi teh 


HED) [E] http://localhost:1230/mySi te/De£axl t. aspx 


Default. aspx. cs 


我 是 跳 转 页 面 TansferTest 


图 解决 方案 中 显示 的 网 站 路 径 图 运行 结果 


如 图 2.7 所 示 ,地址 栏 中 显示 的 是 Default. aspx, 但 是 页 面 上 显示 的 是 TansferTest. 
aspx 页 面 的 内 容 ,页 面 已 经 自动 的 跳 转 到 TansferTest. aspx 页 中 。 这 也 能 看 出 Server. 
Transfer(path) 与 Response. Redirect (url) 两 个 方法 的 不 同 之 处 。 


2.4 小 结 


本 章 主要 讲述 Request Xf £& , Response 对 象 和 Sever 对 象 的 使 用 方式 以 及 3 个 对 象 对 
应 的 属性 和 方法 等 。 


课 后 思考 问题 


1. 什么 是 相对 路 径 ? 什么 是 绝对 路 径 ? 在 网 站 的 开发 中 多 用 什么 路 径 , 是 相对 的 路 径 
还 是 绝对 的 路 径 。 

2. Server. MapPath(" ~ \\") 中 ~ 代表 什么 意思 ? 

3. "Server. Transfer(" ~ \\TansferTest. aspx");” 这 个 路 径 写 法 为 什么 得 用 ~ NN? 不 
用 会 怎么 样 ? 
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第 3 登 标准 控件 


本 章 要 点 

。 使 用 Label 控件 。 

。 使 用 TextBox 控件 。 

。 使 用 DropDownList 控件 。 

。 使 用 ListBox 控件 。 

* 使 用 CheckBox 控件 。 

。 使 用 RadioButton 控件 。 

。 使 用 Image 控件 。 

。 使 用 Button 控件 、LinkButton 控件 和 ImageButton 控件 。 
。 使 用 HyerLink 控件 。 

。 使 用 FileUpload 控件 上 传 文件 。 
。 使 用 Calendar 控件 。 


3.1 Label 控件 


3.1.1 Label 控件 的 属性 


Label 控件 又 称 为 标签 控件 ,主要 用 来 显示 文本 信息 ,此 控件 属于 服务 器 端 标准 控件 。 
label 控件 的 主要 属性 有 ID 和 Text, 

(1) ID: 表示 Label 控件 的 ID 名 称 。 

(2) Text: 表示 Label 控件 显示 的 文本 。 


3.1.2 Label 控件 的 实际 使 用 


本 实例 使 用 Label 控件 显示 文本 。 

主要 实现 步骤 如 下 。 

CD 新 建 一 个 网 站 ,在 默认 主页 Default. aspx 页 面 中 添加 一 个 Label 控件 。 如 图 3. 1 
所 示 ,双击 工具 箱 中 的 Label 控件 ,就 会 在 Default. aspx 页 面 的 设计 视图 添加 一 个 Label 控 
件 , 如 图 3.2 所 示 。 

(2) 在 设计 视图 中 ,选中 Label 控件 ,在 属性 工具 栏 中 设置 Label 控件 的 相应 属性 ,如 
图 3.3 和 图 3. 4 所 示 。 

(3) 也 可 以 在 代码 视图 中 设置 Label 控件 的 属性 ,代码 如 下 : 


protected void Page _ Load (object sender, EventArgs e) 
t 
Label1.Text= "显示 Label 文本 "7 


i 


UCM IGI 
T 控件 


在 工具 箱 中 使 用 控件 图 在 页 面 中 添加 控件 


1 System. Web. UT. WebControls. Label = 


zB 
(Expressions) 
AccessKey: 
AssociatedControl] 


Labell System. Web. UI. WebControls.Label = 
HE 
emus i 


ForeColor 
Height 
SkinID 
TabIndex 


BackColor 
BorderColor 
BorderStyle 
Borderlidth 
CssClass 


CINENENE + 
ToolTip 

Visible True 
Width 


图 设置 控件 的 ”属性 


(4) 最 终 运行 的 结果 如 图 3. 5 所 示 。 


Label 控 件 的 使 用 一 Microsoft Internet Explorer 
Xo) 编辑 FF) FEV KEA IAM 才 助 00 


Q*-Q- 32 Alpa vc |2- 


HAED) [E] http://1ocalhost:1143/test/LableTest. as EEA | 链接 » 
显示 Label 文 本 


[ES NJEH Intranet. 


E 控件 显示 的 文本 


3.2 TextBox 控件 


3.2.1 TextBox 控件 基本 属性 


在 Web 页 面 中 ,常常 使 用 文本 框 控件 (TextBox) 来 接受 用 户 的 输入 信息 ,包括 文本 C 
字 和 日 期 等 。 默 认 情 况 下 ,文本 框 控件 是 一 个 单行 的 文本 框 , 用 户 只 能 输入 一 行内 容 。 但 是 
通过 修改 它 的 属性 ,可 以 将 文本 框 改 为 允许 输入 多 行文 本 或 者 输入 密码 的 形式 ,此 控件 属于 
服务 器 端 标准 控件 。 它 的 主要 属性 包括 ID Text 和 TextMode。 

(1) ID; 表示 TextBox 控件 的 ID 名 称 。 
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(2) Text; 表示 TextBox 控件 显示 的 文本 。 

(3) TextMode: 用 于 控制 TextBox 控件 的 文本 显示 方式 ,该 属性 的 设置 选项 有 以 下 
3 种 。 

(D 单行 (SingleLine): 用 户 只 能 在 一 行 中 输入 信息 ,还 可 以 选择 限制 控件 接收 的 字 
符 数 。 

© 多 行 (MultiLine) : 文本 很 长 时 ,人 允许 用 户 输入 多 行文 本 并 执行 换行 。 


3.2.2 TextBox 控件 的 实际 使 用 


本 实例 通过 设置 TextBox 控件 的 TextMode 属性 来 实现 该 控件 的 3 种 文本 显示 效果 ， 
并 通过 代码 把 页 面 上 填写 的 内 容 输出 出 来 。 

实现 步骤 如 下 。 

CD 新 建 一 个 网 站 ,在 默认 主页 Default. aspx 页 面 中 添加 3 个 TextBox 控件 ,如 图 3.6 
所 示 。 


can 
用 户 名 
密码 E 
E | A  ^&] 
gi. | 
m) [how] 


图 页 面 添加 的 ”个 控件 


O) 在 属性 窗口 中 分 别 设置 TextBox 的 属性 如 下 。 

O AMPAH TextBox 控件 的 TextMode 属性 为 SingleLine。 
© 输入 密码 的 TextBox 控件 的 TextMode 属性 为 Password, 

@ 输入 备注 的 TextBox 控件 的 TextMode 属性 为 MultiLine。 
设计 页 面 TextBoxTest. aspx 的 代码 如 下 : 


<div> 
«table style="width: 419px"> 

<tr> 
<td> 用 户 名 :</td> 
<td><asp:TextBox ID- "username" runat- "server">< /asp:TextBox>< /td> 

</tr> 

«tr» 
«td» tit fi :< /td> 
«td» «asp:TextBox ID- "pwd" runat="server" TextMode- "Password"» « /asp: 

TextBox>< /td> 
SEES 
sd s 


«tr» 
«td» fit: «/td» 
«td»«asp:TextBox ID- "remark" runat="server" Height- "136px" TextMode- 

"MultiLine" Width- "186px"»« /asp:TextBox>< /td> 

</tr> 

<tr> 
«td» « asp:Button ID- "btn" runat="server" Text "注册 " Onclick-"btn Click" /»« /td» 
«td»«asp:Label ID- "show" runat="server" Text="">< /asp:Label»« /td> 

</tr> 

</table> 
</div> 


代码 区 域 TextBoxTest. aspx. cs 的 代码 如 下 : 


protected void btn Click(object sender, EventArgs e) 
{ 


show.Text =" 用 户 名 为 : "+username.Text + "<br/> 密 码 为 : " +pwd.Text + "<br/> 备 注 信息 为 : 


" +remark.Text; 
} 


最 终 运行 的 结果 如 图 3.7 所 示 。 


汉文 本 框 的 使 用 - Wicrosoft Internet Explorer 

文件 FF) (ao) 查看 WV) 收藏 A) IAT) 帮助 00 

Qs -QO- i93 i20 EP ET M ii 
Hiro) la http: //1ocslhost: 1143/test/TextBoxTest. aspx E Drame” 


备注 信息 为 ，sfasdfsdfsdfsdfsd 


3.3 DropDownList 控件 


3.3.1 DropDownList 控件 添加 列表 项 


DropDownList 控件 是 人 们 经 常 使 用 的 下 拉 列 表 , 用 于 收集 用 户 的 选择 信息 。 通 常 
个 DropDownList 控件 创建 一 个 包含 多 个 选项 的 下 拉 列 表 , 用 户 可 以 从 中 选择 一 个 选项 。 
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使 用 DropDownList 控件 时 ,有 两 种 方法 可 以 指定 DropDownList 控件 的 列表 项 : 一 种 
是 通过 逐个 输入 来 输入 列表 项 ; 另 一 种 则 是 通过 绑 定 数据 库 的 方法 指定 列表 项 ,这 种 方法 将 
在 第 7 章 介绍 。 

要 向 DropDownList 控件 中 添加 列表 项 ,就 要 编辑 它 的 tem 属性 。 选 中 当前 的 
DropDownList 控件 ,在 如 图 3. 8 所 示 的 属性 窗口 中 ,滚动 到 Items 属性 。 可 以 看 到 该 属性 
值 当 前 为 Collection。 如 果 单 击 该 属性 值 ,一 个 矩形 的 按钮 将 出 现在 Collection 右边 。 

单 击 该 按钮 ,打开 “ListItem 集合 编辑 器 ”对 话 框 ,如 图 3.9 所 示 。 通 过 该 对 话 框 可 以 向 
DropDownList 控件 添加 编辑 或 删除 列表 项 。 


ListItes 集合 编辑 器 HE 
成 员 00: 
DroplownLi st1 Systen. Web. UI. WebContro m 
图 

Collection] d 
SkinID 
TabIndex 0 
ToolTip 
ValidationGroup M 

Iteas 

列表 中 项 的 集合 。 

图 向 控件 中 添加 列表 项 图 H 集合 编辑 器 ”对 话 框 


单 击 “添加 ”按钮 ,在 “ListItem 集合 编辑 器 "对话 框 左边 的 文本 框 中 将 添加 一 个 新 条 目 ， 
在 右边 将 显示 新 添加 列表 项 的 属性 。 如 图 3. 10 所 示 , 列 表 项 有 4 个 属性 : Enabled, 
Selected, Text 和 Value, 
ListIten RARES HE 
成 员 00: EH REC): 


图 Y 集合 编辑 器 ”对 话 框 


(1) Enabled 属性 指定 列表 项 是 否 能 最 终 在 下 拉 列 表 中 出 现 。 

(2) Selected 属性 指定 在 网 页 被 加 载 的 时 候 该 列表 项 是 否 默 认 被 选择 。 

(3) Text 属性 是 指 下 拉 列 表 中 显示 给 用 户 的 文本 。 

(4) Value 属性 对 用 户 来 说 是 不 可 见 的 , 它 只 是 用 作 一 种 传送 列表 项 相关 信息 的 方法 ， 
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并 不 希望 用 户 看 到 这 些 信息 。 
注意 : 如 果 不 指 定 DropDownList 控件 列表 项 的 Value 属性 ,系统 默认 将 Value 属性 和 
Text 属性 设 为 相同 的 值 。 


3.3.2 获取 DropDownList 控件 列表 项 的 值 


前 面 介绍 的 DropDownList 控件 的 列表 项 有 4 个 属性 : Enabled, Selected, Text 和 
Value。 因 此 ,要 获取 Text 属性 ,可 以 使 用 以 下 方法 : 


DropDownListID.SelectedItem.Text 
同样 ,要 获取 Value 属性 ,可 以 使 用 下 述 方法 : 


DropDownListID.SelectedItem.Value 


3.3.3 DropDownList 控件 的 实际 应 用 


本 实例 通过 设置 DropDownList 控件 的 Item 属性 来 实现 该 控件 的 显示 效果 ,并 通过 代 
码 把 页 面 上 选择 的 内 容 输出 出 来 。 

实现 步 又 如 下 。 

CD 新 建 一 个 网 站 ,在 默认 主页 Default. aspx 页 面 中 添加 1 个 DropDownList 控件 。 

(2) 在 属性 窗口 中 分 别 设置 DropDownList 的 属性 ,如 图 3. 11 所 示 。 


AT Hio: 


*| a 

a| Bam 
Enabled True 
Selected False 
Text 其 他 


图 设计 视图 中 设计 的 页 面 


设计 页 面 Default. aspx 的 代码 如 下 : 


«div» 
你 喜欢 的 运动 是 : «asp:DropDownList ID- "hobby" runat="server"> 
<asp:ListItem Value= "basketball"> 篮 球 < /asp:ListItem> 
<asp:ListItem Value- "football" Æ ER « /asp:ListItem> 
<asp:ListItem Value- "pingpang"» E E; Ef « /asp:Listltem» 
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<asp:ListItem Value= "other"> 其 他 < /asp:Listrtem» 
</asp:DropDownList> 
«br /> 
«asp:Button ID= "Buttonl" runat="server" Text=" 请 选择 " Onclick- "Buttonl Click" /> 
«br /> 
<asp:Label ID- "show" runat- "server">< /asp:Label» 
« /div» 


代码 区 域 Default. aspx. cs 代码 如 下 : 


protected void Buttonl Click (object sender, EventArgs e) 
{ 
show.Text =" 你 喜欢 的 运动 是 : " +hobby.SelectedItem. Text; 
show.Text +="<br/> 你 选择 的 运动 的 value 值 为 : " +hobby.SelectedItem.Value; 


} 
最 终 运 行 的 结果 如 图 3. 12 所 示 。 


ET ELT - mi creseft Internet Explorer 
RED SEV KEN IAM Wbo (| 
-A A ss ge — 
i 0) [Æ http://localhost: 1143/test/Defau t 2| EJ 9630 | E > 


pi rides gx s 


运动 是 , E 
per a CTN: football 


图 使 用 下 拉 列 表 框 的 运行 结果 


3.4 ListBox 控件 


3.4.1 ListBox 控件 添加 列表 项 


ListBox 控件 就 是 人 们 常用 的 列表 框 , 它 的 用 法 以 及 属性 和 DropDownList 控件 非常 相 
似 。 本 节 用 ListBox 控件 实现 和 3. 3. 3 节 利 用 DropDownList 控件 的 示例 差不多 的 功能 。 


3.4.2 ListBox 控件 实际 使 用 


本 实例 通过 设置 ListBox 控件 的 Item 属性 来 实现 该 控件 的 显示 效果 ,并 通过 代码 把 页 
面 上 选择 的 内 容 输 出 出 来 。 

实现 步骤 如 下 。 

CD 新 建 一 个 网 站 ,在 默认 主页 ListBox. aspx 页 面 中 添加 1 个 ListBox 控件 。 

(2) 在 属性 窗口 中 分 别 设置 ListBox 控件 的 Items 属性 。 

设计 页 面 ListBox. aspx 的 代码 如 下 : 


<div> 
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你 喜欢 的 运动 是 : «asp:ListBox ID- "play" runat="server"> 
<asp:ListItem> 篮 球 < /asp:ListItem> 
<asp:ListItem> 足 球 < /asp:ListItem> 
<asp:ListItem> 乒 乓 球 </asp:ListItem> 
<asp:ListItem> 其 他 < /asp:ListItem> 
<asp:ListItem> < /asp:ListItem> 
< /asp:ListBox> 
<asp:Button ID- "submit" runat- "server" Text=" 确 定 " onclick- "submit Click" /> 
«br /> 
<asp:Label ID- "show" runat- "server">< /asp:Label» 
</div> 


代码 区 域 ListBox. aspx. cs 代码 如 下 : 


protected void submit Click (object sender, EventArgs e) 

{ 
show.Text =" 你 喜欢 的 运动 是 : " +play.SelectedItem.Text + "<br/>" +" 你 喜欢 的 运动 是 : "+ 
play.SelectedItem.Value; 

) 


最 终 运行 的 结果 如 图 3.13 所 示 。 


车 列 表 框 的 使 用 - microsoeft Internet Explorer 
XEO RED SEV BÆN IAM 帮助 00 | e 
Qa - O- iX iz Alper vow O| 


HE OD [E] http://1ocslhost:1143/test/ListBox. aspe — Y] EJ P834 | BERE > 


Es 
mb 
你 喜欢 的 运动 是 ， E 确定 


你 喜欢 的 运动 是 ， 足 球 
你 喜欢 的 运动 是 ， 足 球 


图 使 用 控件 的 运行 结果 


3.4.3 ListBox 控件 实现 多 项 选择 


ListBox 控件 比 DropDownList 控件 多 了 可 以 多 选 的 功能 ,设置 ListBox 控件 的 
SelectionMode 属性 为 Multiple, 就 能 实现 多 选 了 。 在 选择 的 时 候 , 按 住 键盘 上 的 Ctrl BERE 
选择 ,以 实现 多 项 选择 。 

本 实例 通过 设置 ListBox 控件 的 SelectionMode 属性 来 实现 该 控件 的 多 项 选择 功能 ,并 
通过 代码 把 页 面 上 选择 的 内 容 输出 出 来 。 

设计 页 面 ListBox. aspx 的 代码 如 下 : 

<div> 

你 喜欢 的 运动 是 : <asp:ListBox ID- "play" runat="server" SelectionMode="Multiple"> 
<asp:ListItem> 篮 球 < /asp:ListItem> 
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<asp:ListItem JÉ EK « /asp:ListItem» 
<asp:ListItem £r FK; Ek « /asp:ListItem» 
<asp:ListItem> 其 他 < /asp:Listrtem» 
<asp:ListItem < /asp:ListItem> 

< /asp:ListBox> 

<asp:Button ID- "submit" runat- "server" 

<br /> 


Text- "确定 " onclick- "submit Click" /> 


<asp:Label ID= "show" runat- "server" « /asp:Label» 
« /div» 


代码 区 域 ListBox. aspx. cs 代码 如 下 : 


protected void submit Click(object sender, EventArgs e) 
t 


show.Text = "你 喜欢 的 运动 是 : "5 
for (int i =0; i «play.Items.Count; i++) 
( if (play.Items[i].Selected) 


{  show.Text *-play.Items[i].Text 4 "«br/» "; 


最 终 运行 的 结果 如 图 3.14 所 示 。 


加 可 以 多 选 的 Li stBoz 控 件 - Microsoft Internet Explore: 
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图 使 用 可 以 多 选 的 控件 的 运行 结果 


3.5 CheckBox 控件 


3.5.1 CheckBox 控件 基本 属性 


CheckBox 控件 用 于 在 ASP. NET 中 添加 一 个 复 选 框 。 主 要 属性 有 ID 和 Checked. nf 


以 使 用 CheckBoxID. Checked 属性 来 指定 , 它 将 返回 一 个 True 和 False 值 ,来 确定 该 复 选 
框 有 没有 被 选 定 


下 面 用 一 个 选择 运 动 的 例子 来 说 明 CheckBox 控件 的 使 用 。 
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设计 页 面 CheckBox. aspx 的 代码 如 下 : 


<div> 
你 喜欢 的 运动 是 : <br /> 
«asp:CheckBox ID- "bask" runat="server" Text- "篮球 " /»«br /> 
«asp:CheckBox ID- "foot" runat="server" Text- "足球 " /»«br /> 
«asp:CheckBox ID- "ping" runat="server" Text- "乒乓 球 " /»«br /> 
«asp:CheckBox ID- "other" runat="server" Text- "其 他 " /» «br /> 
« asp:Button ID- "submit" runat="server" OnClick- "submit Click" Text- "HE" /> 
<br /> 
<asp:Label ID- "show" runat- "server">< /asp:Label» 

</div> 


代码 区 域 CheckBox. aspx. cs 代码 如 下 : 


protected void submit Click (object sender, EventArgs e) 
t 

show.Text = "你 喜欢 的 运动 是 : "5 

if (bask.Checked) 

{ show.Text +=bask.Text + "«br/»"; 

) 

if (foot.Checked) 

{ show.Text +=foot.Text +"<br/> "7 


if (ping.Checked) 
{ show.Text +=ping.Text 4 "«br/»"; 


if (other.Checked) 
{ show.Text +=other.Text * "«br/»"; 


最 终 的 运行 结果 如 图 3. 15 所 示 。 


沾 checkBoz 榨 件 的 使 用 - microsoeft Internet Exzplorer 


文件 中) RED FEV KEN IAT) 帮助 00 
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HED) (Æ) http://localhost: 1161/test/CheckBox. aspx 


你 喜欢 的 运动 是 ， 
区 篮球 


区 足球 
口 乒 乓 球 
T Ri 
确定 


你 喜欢 的 运动 是 ， 篮 球 
足球 


图 使 用 控件 的 运行 结果 


3.5.2 CheckBoxList 控件 


为 了 方便 复 选 控件 的 使 用 ,. NET 服务 器 控件 中 包括 了 复 选 组 控件 , 拖 动 一 个 复 选 组 控 
件 到 页 面 可 以 添加 复 选 组 列表 。 


在 网 页 CheckBoxList. aspx 中 加 入 CheckBoxList 控件 ,编辑 CheckBoxList 控件 的 
Items 属性 ,添加 相应 的 选项 。 添 加 步骤 同 DropDownList 控件 。 
设计 页 面 CheckBoxList. aspx 的 代码 如 下 : 


<div> 
你 喜欢 的 运动 是 : <br /> 
<asp:CheckBoxList ID= "play" runat= "server"> 
<asp:ListItem {ER< /asp:ListItem» 
<asp:ListItem Æ $R< /asp:ListItem> 
<asp:ListItem Ir f; ER « /asp:ListItem> 
<asp:ListItem H fli « /asp:ListItem» 
< /asp:CheckBoxList» «br /> 
«asp:Button ID- "submit" runat- "server" OnClick-"sumit Click" Text- "lf; " /» «br /> 
<asp:Label ID- "show" runat- "server". /asp:Label» 
</div> 


代码 区 域 CheckBoxList. aspx. cs 代码 如 下 : 
protected void submit Click (object sender, EventArgs e) 
t 

show.Text = "你 喜欢 的 运动 是 : "5 

for (inti =0; i «play.Items.Count; i++) 

{ if (play.Items[i].Selected) 


{ show.Text *-play.Items[i].Text 4 "«br/»"; 
$ 


} 


最 终 的 运行 结果 如 图 3. 16 所 示 。 


HAED) [Æ http://1ocalhost: tl61/test/CheckBoxList. asx HORAE 
你 喜欢 的 运动 是 ， 
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确定 
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3.6 RadioButton 控件 


3.6.1  RadioButton 控件 基本 属性 


RadioButton 控件 用 于 在 ASP. NET 网 页 中 添加 单 选 按钮 ,用 于 从 一 个 有 效 选 项 列表 
中 选择 一 个 选项 。 可 以 将 单 选 按钮 编 成 相关 的 组 。 给 定 一 组 相关 按钮 ,不 能 同时 选中 多 个 
单 选 按钮 ,也 就 是 说 ,相关 按钮 互 斥 。 在 网 页 中 加 入 RadioButton 控件 时 ,加 入 的 多 个 
RadioButton 控件 并 不 互 斥 ,也 就 是 说 可 以 选择 多 个 单 选 按钮 ,如 何 实现 一 次 只 能 选择 一 个 
单 选 按钮 ,这 就 需要 设置 RadioButton 控件 的 GroupName 属性 。 单 选 控件 常用 属性 如 下 
Bim. 

(D) Checked; 控件 是 否 被 选中 。 

(2) GroupName: 单 选 控件 所 处 的 组 名 。 

单 选 控件 通常 需要 Checked 属性 来 判断 某 个 选项 是 否 被 选中 ,多 个 单 选 控件 之 间 可 能 
存在 着 某 些 联系 ,这 些 联系 通过 GroupName 进行 约束 和 联系 。 

本 实例 通过 设置 RadioButton 控件 的 相应 属性 来 实现 该 控件 的 选择 功能 ,并 通过 代码 
把 页 面 上 选择 的 内 容 输出 出 来 。 

设计 页 面 RadioButton. aspx 的 代码 如 下 : 


<div> 
你 喜欢 的 运动 是 : <br /> 
< asp:RadioButton ID- "bask" runat- "server" GroupName- "sport" Text= "篮球 " /> 
« asp:RadioButton ID= "foot" runat="server" GroupName- "sport" Text- "Jf RR" /> 
< asp:RadioButton ID= "ping" runat="server" GroupName- "sport" Text- "Ir Iz Ej" /> 
« asp:RadioButton ID- "other" runat="server" GroupName- "sport" Text=" 其 他 " /> 
<br /> 
«asp:Button ID- "submit" runat="server" onclick- "submit Click" Text- "确定 " /> 
<br /> 
<asp:Label ID- "show" runat- "server" « /asp:Label^ 

</div> 


代码 区 域 RadioButton. aspx. cs 代码 如 下 : 


protected void submit Click (object sender, EventArgs e) 
t 
if (bask.Checked) 
{  show.Text = "你 喜欢 的 运动 是 篮球 nz 
} 
else 
if (foot.Checked) 
{ 
show.Text =" 你 喜欢 的 运动 是 足球 。"; 
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else 

if (ping.Checked) 

{ show.Text =" 你 喜欢 的 运动 是 乒乓 球 。"; 

} 

else 
if (other.Checked) 
{ show.Text =" 你 喜欢 的 运动 是 其 他 。"; 
} 
else 
{ ”show.Text =" 你 没 选择 任何 项 。"; 
) 

} 


最 终 的 运行 结果 如 图 3. 17 所 示 。 
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3.6.2 RadioButtonList 控件 


与 单 选 控件 相同 , 单 选 组 控件 也 是 只 能 选择 一 个 项 目的 控件 ,而 与 单 选 控件 不 同 的 是 ， 
单 选 组 控件 没有 GroupName 属性 ,但 是 却 能 够 列 出 多 个 单 选项 目 。 另 外 , 单 选 组 控件 所 生 
成 的 代码 也 比 单 选 控件 实现 的 相对 较 少 。 

在 网 页 RadioButtonList. aspx 中 加 入 RadioButtonList 控件 ,编辑 RadioButtonList 控 
件 的 Items 属性 ,添加 相应 的 选项 。 添 加 步骤 同 DropDownList 控件 。 

设计 页 面 RadioButtonList. aspx 的 代码 如 下 : 


«div» 

你 喜欢 的 运动 是 : <br /> 

«asp:RadioButtonList ID-"sportl" runat="server"> 
<asp:ListItem Íl ER « /asp:ListItem» 
<asp:ListItem f EK « /asp:ListItem» 
<asp:ListItem Ir E; ER « /asp:ListItem» 
<asp:ListItem H.[li « /asp:Listrtem» 

< /asp:RadioButtonList» 

«asp:Button ID- "submitl" runat="server" onclick- "submitl Click" Text- "确定 " /> 

<asp:Label ID- "showl" runat- "server" « /asp:Label» 

. 24 。 


«br /> 
</div> 


代码 区 域 RadioButtonList. aspx. cs 代码 如 下 ; 


protected void submitl Click (object sender, EventArgs e) 


t 
showl.Text = "你 喜欢 的 运动 是 " + sport1.Text; 
} 


最 终 的 运行 结果 如 图 3. 18 所 示 。 
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3.7 Image 控件 


t. aspx 


控件 的 运行 结果 


图 像 控件 用 来 在 Web 窗 体 中 显示 图 像 ,图 像 控 件 常用 的 属性 如 下 。 
(1) AlternateText: 在 图 像 无 法 显 式 时 显示 的 备用 文本 。 


(2) ImageAlign: 图 像 的 对 齐 方式 。 
(3) ImageUrl: 要 显示 图 像 的 URL. 


当 图 片 无 法 显示 的 时 候 , 图 片 将 被 替换 成 AlternateText 属性 中 的 文字 ,ImageAlign 属 
性 用 来 控制 图 片 的 对 齐 方式 ,而 ImageUrl 属性 用 来 设置 图 像 链接 地 址 。 同 样 ,HTML 中 也 
可 以 使 用 二 img sre="" alt 王 "过 来 蔡 代 图 像 控件 ,图 像 控 件 具 有 可 控 性 的 优点 ,就 是 通过 
编程 来 控制 图 像 控件 ,图像 控件 基本 声明 代码 如 下 : 


<asp:Image ID= "Imagel" runat="server" /> 


除了 显示 图 形 以 外 ,Image 控件 还 有 一 些 其 他 属性 (可 以 为 图 像 指 定 各 种 文本 ): 
(4) ToolTip: 浏览 器 显 式 在 工具 提示 中 的 文本 。 


(5) GenerateEmptyAlternateText: 如 果 将 此 
性 将 设置 为 空 。 


属性 设置 为 True, 则 呈现 的 图 片 的 alt 属 


开发 人 员 能 够 为 Image 控件 配置 相应 的 属性 以 便 在 浏览 时 呈现 不 同 的 样式 ,创建 一 个 
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Image 控件 也 可 以 直接 通过 编写 HTML 代码 进行 呈现 ,示例 代码 如 下 : 


<asp:Image ID- "Imagel" runat="server" AlternateText- "图 片 连接 失效 "ImageUr1= 

"~ /images/cms . jpg" /> 

上 述 代码 设置 了 一 个 图 片 ,并 当 图 片 失 效 的 时 候 提 示 图 片 连接 失效 。 

注意 : 当 双 击 图 像 控 件 时 ,系统 并 没有 生成 事件 所 需要 的 代码 段 , 这 说 明 Image 控件 不 
支持 任何 事件 。 


3.8 按钮 控件 


3.8.1 按钮 控件 的 属性 


在 Web 应 用 程序 和 用 户 交互 时 ,常常 需要 提交 表单 .获取 表单 信息 等 操作 。 在 这 期 间 ， 
按钮 控件 是 非常 必要 的 。 按 钮 控件 能 够 触发 事件 ,或 者 将 网 页 中 的 信息 回 传 给 服务 器 。 在 
ASP. NET 中 ,包含 三 类 按钮 控件 ,分 别 为 Button、LinkButton fil ImageButton, 

下 面 的 语句 声明 了 3 种 按钮 ,示例 代码 如 下 : 

<asp:Button ID= "Buttonl" runat- "server" Text- "Button" /> // 普 通 的 按钮 <br /> 


«asp:LinkButton ID- "LinkButtonl" runat="server"> LinkButton« /asp:LinkButton> 
//Link 类 型 的 按钮 <br /> 


«asp:ImageButton ID- "ImageButtonl" runat="server" /> // 图 像 类 型 的 按钮 
对 于 3 种 按钮 ,它们 起 到 的 作用 基本 相同 ,主要 是 表现 形式 不 同 ,如 图 3. 19 所 示 。 
3.8.2 按钮 控件 的 Click 事件 Ol x 


Kee http://10e... e] f n] x] [e 


这 3 种 按钮 控件 对 应 的 事件 通常 是 Click 单 击 事 
TF. 在 Click 单 击 事件 中 ,通常 用 于 编写 用 户 单 击 按钮 
时 所 需要 执行 的 事件 ,示例 代码 如 下 : 


protected void Buttonl Click (object sender, EventArgs 
e) 
(Labell.Text =" 普 通 按钮 被 触发 "; ——— // 输 出 信息 


} 
protected void LinkButtonl Click (object sender, 


EventArgs e) 
( Labell.Text = "h BE Hz H B ik"; // 输 出 信息 


} 
protected void ImageButtonl Click (object sender, ImageClickEventArgs e) 


{ Labell.Text =" 图 片 按钮 被 触发 "5 // 输 出 信息 

} 

上 述 代码 分 别 为 3 种 按钮 生成 了 事件 ,其 代码 都 是 将 Labell 的 文本 设置 为 相应 的 文 
本 ,运行 结果 如 图 3. 20 所 示 。 
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3.9 HyperLink 控件 


超 链 接 控件 相当 于 实现 了 HTML 代码 中 的 二 a href — "" — —/a2 "HORE , 2 PA Lol Bf BE 
控件 有 自己 的 特点 , 当 拖 动 一 个 超 链接 控件 到 页 面 时 ,系统 会 自动 生成 控件 声明 代码 ,示例 
代码 如 下 : 


<asp:HyperLink ID= "HyperLinkl" runat= "server"> HyperLink< /asp:HyperLink> 


上 述 代码 声明 了 一 个 超 链 接 控件 ,相对 于 HTML 代码 形式 , 超 链接 控件 可 以 通过 传递 
指定 的 参数 来 访问 不 同 的 页 面 。 当 触发 了 一 个 事件 后 , 超 链 接 的 属性 可 以 被 改变 。 超 链接 
控件 通常 使 用 的 两 个 属性 如 下 。 

(1) ImageUrl: 要 显 式 图 像 的 URL. 

(2) NavigateUrl: 要 跳 转 的 URL. 

1. ImageUrl 属性 

设置 ImageUrl 属性 可 以 设置 这 个 超 链 接 是 以 文本 形式 显 式 还 是 以 图 片 文件 显 式 , 示 
例 代码 如 下 : 


<asp:HyperLink ID- "HyperLinkl" runat- "server" 
ImageUrl- "~ /images/ams.jpg"» 
HyperLink 
< /asp:HyperLink» 
上 述 代码 将 文本 形式 显示 的 超 链 接 变 为 了 图 片 形式 的 超 链接 ,虽然 表现 形式 不 同 ,但 是 
不 管 是 图 片 形式 还 是 文本 形式 ,全 都 实现 的 相同 的 效果 。 
2. Navigate 属性 
Navigate 属性 可 以 为 无 论 是 文本 形式 还 是 图 片 形式 的 超 链 接 设 置 超 链接 属性 , 即 即 将 
跳 转 的 页 面 ,示例 代码 如 下 : 


«asp:HyperLink ID- "HyperLinkl" runat- "server" 
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ImageUrl- "~ /images/ams.jpg" 
NavigateUrl- "http://www.Sina.com"» 
HyperLink 
< /asp:HyperLink» 
上 述 代码 使 用 了 图 片 超 链接 的 形式 。 其 中 图 片 来 自 本 地 网 站 /images/cms. jpg, 当 单 击 此 超 
链接 控件 后 ,浏览 器 将 跳 到 URL X http://www. sina. com 的 页 面 。 


3.10 FileUpload 控件 


在 开发 网 站 的 时 候 , 有 时 候 要 求 网 站 或 者 系统 有 上 传 文件 的 功能 ,这 样 可 以 直接 将 文件 
上 传 到 服务 器 中 。 在 ASP. NET 中 ,通过 使 用 FileUpload 控件 可 以 方便 地 实现 文件 的 
上 传 。 
首先 要 了 解 FileUpload 控件 的 几 个 相关 的 属性 和 方法 。 
(1) 通过 FileUploadID. PostedFile. FileName 可 以 获得 通过 FileUpload 控件 选择 的 文 
件 的 完整 的 文件 名 。 
(2) 通过 FileUploadID. PostedFile. ContentLength 可 以 获得 通过 FileUpload 控件 选 
择 的 文件 大 小 。 
(3) 通过 FileUploadID. PostedFile. SaveAs(URL) 这 个 方法 将 通过 FileUpload 控件 选 
择 的 文件 上 传 到 服务 器 相关 的 URL 中 。 
(4) 通过 Server. MapPath() 这 个 函数 可 以 获取 当前 服务 器 的 路 径 。 
本 实例 通过 在 网 页 FileUpload. aspx 中 添加 FileUpload 控件 实现 文件 的 提交 ,把 文件 
提交 到 本 网 站 的 upload 文件 夹 中 。 如 果 提 交 成 功 就 显示 提交 成 功 ,如 果 失 败 , 显 示 提 交 
设计 页 面 FileUpload. aspx 的 代码 如 下 : 
<div> 
文件 上 传 : «asp:FileUpload ID- "FileUploadl" runat- "server" /> 
«asp:Button ID- "upload" runat="server" onclick- "upload Click" Text=" 上 传 " /> 
<br /> 
<asp:Label ID- "show" runat- "server">< /asp:Label» 
</div> 


代码 区 域 FileUpload. aspx. cs 代码 如 下 : 


protected void upload Click (object sender, EventArgs e) 


{ if (FileUploadl.PostedFile !-null) // 检 查 文件 是 否 上 传 
( string nam -FileUploadl.PostedFile.FileName; ”// 获 取 上 传 文件 的 文件 名 
int i -nam.LastIndexoOf ("."); // 取 得 扩展 名 在 文件 名 中 的 位 置 
string newext =nam. Substring (i); // 取 得 文件 扩展 名 


DateTime now =DateTime .Now7 

String newname —now.DayOfYear.ToString() 
*FileUploadl.PostedFile.Contentlength.TosString ); ”// 这 样 处 理 文件 名 是 确保 文件 名 不 重复 
try 
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{  // 保 存 文件 到 upload 3c (ste rf 
FileUploadl.PostedFile.SaveAs (Server.MapPath ("~ NuploadNV") +newname + 
newext); 
show.Text =" 上 传 成 功 "; 

} 

catch 

{ show.Text =" 上 传 失败 "; 

} 


最 终 运行 的 结果 如 图 3. 21 一 图 3.23 所 示 。 
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3.11 Calendar 控件 


在 实际 的 网 页 使 用 中 ,时 常会 需要 网 页 有 日 历 功 能 ,让 用 户 可 以 很 地 查看 当前 日 期 以 及 
通过 日 历 选择 日 期 。 

在 网 页 Calendar. aspx 中 加 入 Calendar 控件 , 单 击 菜单 自动 套用 格式 可 以 选择 一 个 系 
统 中 自 带 的 样式 ,比如 选择 彩色 型 1 ,运行 结果 如 图 3. 24 所 示 。 

可 以 使 用 Calendar 控件 的 SelectedDate 属性 ,来 显示 当前 选中 的 日 期 。 在 网 页 中 加 
label 控件 ,用 来 显示 选中 的 日 期 。 

设计 页 面 Calendar. aspx 的 代码 如 下 : 


«div» 
«asp:Calendar ID- "Calendarl" runat="server" OnSelectionChanged- "Calendarl - 
Selectionchanged'» 
< /asp:Calendar» 
<asp:Label ID- "show" runat- "server">< /asp:Label» 
</div> 


代码 区 域 Calendar. aspx. cs 代码 如 下 : 


protected void Page Load (object sender, EventArgs e) 

{ Calendarl.SelectedDate - DateTime.Today; // 获 取 当 前 日 期 

} 

protected void Calendarl SelectionChanged (object sender, EventArgs e) 
{ show.Text =Calendarl .SelectedDate.ToString (); 

} 


最 终 运行 的 结果 如 图 3. 25 所 示 。 
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图 控件 的 显示 图 选择 日 期 后 运行 的 结果 


仔细 观察 运行 结果 可 以 发 现 ,返回 的 日 期 值 并 不 是 单独 的 日 期 ,而 是 带 有 时 间 , 这 是 因 
为 通过 Calendar 控件 的 SelectedDate 属性 返回 的 是 一 个 DateTime 类 型 的 变量 ,这 种 类 型 
0 


的 变量 默认 的 返回 值 既 包 括 日 期 也 包括 时 间 。 如 果 和 希望 单独 地 返回 日 期 ,而 不 需要 时 间 的 
话 , 可 以 通过 ToShortDateString 方法 实现 。ToShortDateString 方法 的 功能 是 将 一 个 
DateTime 类 型 的 值 转换 为 等 效 的 短 日 期 形式 的 字符 串 表 现形 式 , 代 码 如 下 : 

protected void Calendarl SelectionChanged (object sender, EventArgs e) 


1 show.Text —Calendarl.SelectedDate.ToShortDateString|() .ToString(); 
} 


3.12 小 结 


本 章 主 要 讲述 了 ASP. NET 中 基本 控件 的 使 用 ,包括 基本 控件 的 添加 、 基 本 控件 的 属 
性 设置 和 基本 控件 的 后 台 取 值 等 。 


课 后 思考 问题 


1. 在 本 章 中 讲述 FileUpload 控件 时 ,仅仅 讲述 了 如 何 上 传 文件 ,如 果 上 传 时 还 要 检验 
上 传 的 文件 是 否 合 法 ,上 传 的 文件 大 小 ,如 何 实 现 ?” 比 方 说 只 能 上 传 图 片 文件 ,上 传 的 大 小 
不 能 大 于 50KB。 

2. 学 习 了 基本 控件 的 使 用 后 , 课 后 实现 图 3. 26 所 示 的 注册 功能 。 
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第 4 音 验证 控件 的 使 用 


本 章 要 点 

如 何 使 用 RequiredFieldValidator 控件 来 确保 用 户 提供 了 输入 。 

如 何 使 用 RangeValidator 控件 来 保证 用 户 的 输入 在 某 个 范围 内 。 

。 如 何 使 用 CompareValidator 控件 来 进行 比较 。 

* 如 何 使 用 RegularExpressionValidator 控件 来 控制 填写 的 内 容 格 式 正确 。 
。 如 何 使 用 CustomValidator 控件 。 


4.1 验证 控件 概述 


在 通常 的 Web 使 用 中 ,要 确保 用 户 的 输入 采用 合适 的 格式 ,也 就 是 说 输入 验证 是 很 重 
要 的 一 个 方面 。 例 如 ,在 注册 用 户 信息 时 ,需要 填写 用 户 名 、 密 码 .电子 邮件 等 信息 。 对 于 不 
同 的 用 户 输入 信息 ,有 着 不 同 的 验证 规则 。 例 如 ,用 户 名 不 能 为 空 ,密码 和 确认 密码 一 致 , 电 
子 邮 件 的 输入 必须 符合 规则 等 。 

在 ASP. NET 中 ,使 用 验证 控件 ,可 以 使 输入 验证 变 得 非常 简单 ,本章 就 介绍 如 何 使 用 
验证 控件 。 

本 章 将 介绍 5 种 验证 控件 , 表 4.1 总 结 了 它们 的 各 自 的 特点 。 


表 4.1 ASP. NET 验证 控件 


验证 控件 验证 类 型 d R 
RequiredFieldValidator 必 填 字段 验证 | 确保 在 特定 输入 中 存在 数据 
RangeValidator 范围 验证 确保 输入 的 数字 位 于 两 个 常数 之 间 


数据 类 型 验证 | 确保 输入 值 小 于 、 小 于 等 于 、 大 于 、 大 于 等 于 或 不 等 于 某 个 
和 比较 验证 | 常数 或 者 用 户 输入 值 。 还 可 以 执行 数据 类 型 验证 


RegularExpressionValidator | 模式 验证 确保 字符 串 与 指定 模式 匹配 
CustomValidator 自 定义 验证 调用 用 户 定义 的 功能 来 执行 标准 验证 程序 不 能 处 理 的 验证 


CompareValidator 


4.2 RequiredFieldValidator 控件 


4.2.1 RequiredFieldValidator 控件 的 基本 属性 


在 实际 的 应 用 中 ,如 在 用 户 填 写 表 单 时 ,有 一 些 项 目 是 必 填 项 ,例如 用 户 名 和 密码 。 在 
ASP.NET 中 ,系统 提供 了 RequiredFieldValidator 验证 控件 进行 验证 。 使 用 RequiredField- 
Validator 控件 能 够 指定 某 个 用 户 在 特定 的 控件 中 必须 提供 相应 的 信息 ,如 果 不 填写 相应 的 
信息 ,RequiredFieldValidator 控件 就 会 提示 错误 信息 。RequiredFieldValidator 控件 的 主要 
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属性 如 下 。 
(1) ID; 验证 控件 的 ID 名 称 。 
(2) ControlToValidate: 指定 验证 控件 用 于 验证 的 是 哪个 输入 控件 。 
(3) ErrorMessage: 输入 错误 时 显示 的 错误 信息 。 
这 3 个 属性 也 是 所 有 的 验证 控件 都 具有 的 基本 属性 。 


4.2.2 RequiredFieldValidator 控件 的 实际 使 用 


本 实例 通过 在 网 页 中 添加 两 个 文本 框 ,分 别 是 姓名 和 密码 ,要 求 这 两 个 控件 必 填 ,用 
RequiredFieldValidator 控件 来 实现 验证 。 

实现 步骤 如 下 。 

CD 在 页 面 中 分 别 添加 两 个 文本 框 ,一 个 ID 为 username 53 — 4 ff] ID 为 pwd, 再 通过 
工具 箱 中 的 验证 部 分 找到 RequiredFieldValidator 控件 添加 两 个 RequiredFieldValidator 验 
证 控件 ,结果 如 图 4.1 所 示 。 

(2) 设置 第 一 个 RequiredFieldValidator 控件 的 ControlToValidate 为 姓名 的 输入 文本 
HE (username) , ErrorMessage 属性 为 姓名 必须 填写 。 设 置 第 二 个 RequiredFieldValidator 
控件 的 ControlToValidate 为 密码 的 输入 文本 框 C(pwd),ErrorMessage 属性 为 密码 必须 填 
写 。 结 果 如 图 4.2 所 示 。 


图 设计 视图 中 的 显示 效果 图 添加 了 相应 属性 后 的 结果 


(3) 完成 上 面 两 步 后 就 能 实现 效果 了 ,运行 页 面 单 击 “ 提 交 ” 按 钮 ,如 图 4. 3 所 示 。 
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E 运行 结果 


设计 页 面 Default. aspx 的 代码 如 下 ; 


«div» 
姓名 : <asp:TextBox ID- "username" runat- "server">< /asp:TextBox» 
«asp:RequiredFieldValidator ID- "valName" runat="server" ErrorMessage- 
"姓名 必须 填写 " Control TeValidate- "username" < /asp:RequiredFieldValidator» 
<br /> 
密码 : <asp:TextBox ID- "pwd" runat- "server" TextMode- "Password"> < /asp:TextBox» 
«38 « 


«asp:RequiredFieldValidator ID= "valPwd" runat="server" ErrorMessage- "密码 必须 填写 " 
ControlToValidate- "pwd"» « /asp:RequiredFieldValidator» «br /> 
«asp:Button ID- "Buttonl" runat="server" Text- "提交 " /> 

</div> 


4.3 RangeValidator 控件 


4.3.1 RangeValidator 控件 的 基本 属性 


范围 验证 控件 (RangeValidator) 可 以 检查 用 户 的 输入 是 否 在 指定 的 上 限 与 下 限 之 间 。 
通常 情况 下 用 于 检查 数字 .日 期 .货币 等 。 范 围 验 证 控件 (RangeValidator) 控 件 的 常用 属性 
包括 验证 控件 的 基本 属性 和 如 下 所 示 的 特有 属性 。 

(D MinimumValue; 指定 有 效 范围 的 最 小 值 。 

(2) MaximumValue: 指定 有 效 范围 的 最 大 值 。 

(3) Type: 指定 要 比较 的 值 的 数据 类 型 。 


4.3.2 RangeValidator 控件 的 实际 使 用 


本 实例 通过 在 网 页 中 添加 一 个 年 龄 的 文本 框 ,要 求 这 年 龄 控件 必须 在 0 一 200 岁 之 间 ， 
用 RangeValidator 控件 来 实现 验证 。 

实现 步 又 如 下 。 

CD 在 页 面 中 添加 年 龄 文本 框 ,ID 设置 为 age, 如 图 4.4 所 示 。 

(2) 设置 RangeValidator 控件 的 ControlToValidate 属性 和 ErrorMessage 属性 。 由 于 
RangeValidator 控件 是 对 age 文本 框 进行 验证 ,所 以 将 它 的 ControlToValidate 属性 设置 为 
age,ErrorMessage 属性 设置 为 “年 龄 应 该 在 0 一 200 岁 之 间 ”。 

(3) 然后 再 设置 RangeValidator 控件 的 MaximumValue 和 MimimumValue 属性 ， 
MaximumValue 设置 为 200,MimimumValue 设置 为 0。Type 属性 设置 为 Integer, 

(4) 完成 上 面 三 步 后 就 能 实现 效果 了 ,运行 页 面 单 击 “ 提 交 ” 按 钮 ,如 图 4.5 所 示 。 
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设计 页 面 Default. aspx 的 代码 如 下 ; 


年 龄 : <asp:TextBox ID- "age" runat- "server">< /asp:TextBox> 
«asp:RangeValidator ID- "valAge" runat- "server" ControlToValidate- "age" 


» 34 a 


ErrorMessage- "年 龄 应 该 在 0-200 岁 之 间 " 
MaximmValue= "200" MinimmValue="0" Type- "Integer'^» < /asp:RangeValidator» «br /> 
«asp:Button ID- "Buttonl" runat="server" Text- "提交 " /> 


4.4  CompareValidator 控件 


4.4.1 CompareValidator 控件 的 基本 属性 


比较 验证 控件 对 照 特 定 的 数据 类 型 来 验证 用 户 的 输入 。 因 为 当 用 户 输入 用 户 信息 时 ， 
难免 会 输入 错误 信息 ,如 当 需 要 了 解 用 户 的 生日 时 ,用 户 很 可 能 输入 了 其 他 的 字符 串 。 
CompareValidator 比较 验证 控件 能 够 比较 控件 中 的 值 是 否 符合 开发 人 员 的 需要 。 
CompareValidator 控件 的 特有 属性 如 下 。 

(D) ControlToCompare: 以 字符 串 形式 输入 的 表达 式 。 要 与 另 一 控件 的 值 进 行 比较 。 

(2) Operator: 要 使 用 的 比较 。 

(3) Type: 要 比较 两 个 值 的 数据 类 型 。 

(4) ValueToCompare: 以 字符 串 形式 输入 的 表达 式 。 


4.4.2 CompareValidator 控件 在 实际 中 的 使 用 


本 例 通过 添加 一 个 确认 密码 ,要 求 确 认 密 码 跟 密 码 一 致 。 通 过 CompareValidator 控件 

(1) 在 页 面 中 添加 一 个 确认 密码 的 文本 框 , 并 改 ID 为 repwd, 添 加 一 个 CompareValidator 控 
件 , 把 它 的 ControlToValidate 属性 和 ErrorMessage 属性 分 别 设置 为 repwd 和 “确认 密码 必 
须 跟 密码 一 致 "。 结 果 如 图 4.6 所 示 。 


图 设计 视图 中 添加 确认 密码 后 的 结果 


(2) 然后 设置 ControlToCompare 属性 为 pwd. Type 属性 为 String. Operator 属性 为 
Equal, 
(3) 最 终 的 运行 结果 如 图 4.7 所 示 。 
设计 页 面 Default. aspx 的 代码 如 下 : 
确认 密码 : <asp:TextBox ID= "repwd" runat= "server">< /asp:TextBox> 
< asp: CompareValidator ID =" valRePwd" runat =" server" ControlToCompare =" pwd" 


ControlToValidate- "repwd" ErrorMessage- "确认 密码 必须 跟 密码 一 致 " Type- "String" Operator-" 
Equal">< /asp:CompareValidator» «br /> 


. 35 。 


当 无 标题 页 - microeseft Internet Explorer 
XD d Bo) EEV BEN IAT 帮助 00 


Qs -O-ha gpr rm 6| 


HAED) [E http://1ocalhost:1034/test/Defat.aspx Z| EJES | EE > 
x] 


4.5 RegularExpressionValidator 控件 


4.5.1  RegularExpressionValidator 控件 的 基本 属性 


在 上 述 控件 中 ,虽然 能 够 实现 一 些 验证 ,但 是 验证 的 能 力 是 有 限 的 ,例如 在 验证 的 过 程 
中 ,只 能 验证 是 否 是 数字 ,或 者 是 否 是 日 期 。 也 可 能 在 验证 时 ,只 能 验证 一 定 范围 内 的 数值 ， 
虽然 这 些 控件 提供 了 一 些 验 证 功能 ,但 却 限制 了 开发 人 员 进 行 自 定义 验证 和 错误 信息 的 开 
发 。 为 实现 一 个 验证 ,很 可 能 需要 多 个 控件 同时 搭配 使 用 。 

正则 验证 控件 (RegularExpressionValidator) 就 解决 了 这 个 问题 ,正则 验证 控件 的 功能 
非常 强大 , 它 用 于 确定 输入 的 控件 的 值 是 否 与 某 个 正则 表达 式 所 定义 的 模式 相 匹 配 ,如 电子 
邮件 、 电 话 号 码 以 及 序列 号 等 。 

正则 验证 控件 (RegularExpressionValidator) | peme: 
常用 的 属性 是 ValidationExpression, 它 用 来 指定 
用 于 验证 的 输入 控件 的 正则 表达 式 。 客 户 端的 正 
则 表达 式 验证 语法 和 服务 端的 正则 表达 式 验证 语 ex 
法 不 同 , 因 为 在 客户 端 使 用 的 是 JScript 正则 表达 | qRaunnan us SS 
式 语法 ,而 在 服务 器 端 使 用 的 是 Regex 类 提供 的 取消 
正则 表达 式 语 法 。 使 用 正则 表达 式 能 够 实现 强大 
字符 串 的 匹配 并 验证 用 户 的 输入 的 格式 是 否 正 
确 , 系 统 提供 了 一 些 常 用 的 正则 表达 式 , 开 发 人 员 能 够 选择 相应 的 选项 进行 规则 筛选 ,如 
图 4.8 所 示 。 


图 系统 提供 的 正则 表达 式 


4.5.2 RegularExpressionValidator 控件 在 实际 中 的 使 用 


本 例 通过 添加 一 个 电子 邮件 ,用 RegularExpressionValidator 控件 验证 电子 邮件 的 地 
址 是 否 合法 。 
(1) 在 页 面 上 添加 一 个 电子 邮件 的 文本 框 ,ID 为 E-mail。 
(2) 在 页 面 上 添加 一 个 RegularExpressionValidator 控件 ,设置 它 的 ControlToValidate 属 
性 为 Email,ErrorMessage 属性 为 “邮件 地 址 不 正确 ”。 
AD us 


(3) 修改 RegularExpressionValidator 控件 的 ValidationExpression 属性 , Jf if; 
ValidationExpression 属性 旁边 的 副 按 钮 ,就 会 弹出 正则 表达 式 编辑 器 .从 中 选择 Internet 
电子 邮件 地 址 ,最 终 ValidationExpression 属性 中 会 显示 如 下 的 正则 表达 式 : \w 十 ([ 一 十 . T 
wt) * QNw-4 XO —. Nw4) *NNw-TQGQ-—.Nw42*, 

(4) 最 终 运 行 的 结果 如 图 4. 9 所 示 。 
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设计 页 面 Default. aspx 的 代码 如 下 ; 


电子 邮件 : <asp:TextBox ID= "Email" runat- "server">< /asp:TextBox» 
«asp:RegularExpressionValidator ID= "valEmail" runat="server" ControlToValidate- 

"Email" ErrorMessage- "邮件 地 址 不 正确 " ValidationExpression- "Ww ([-+ .'] Nw) * @\w+ ([- .]N 
w+) * N.N ([- .]\w+) * ">< /asp:RegularExpressionValidator» «br /> 

«asp:Button ID- "Buttonl" runat="server" Text- "提交 " /> 


4.6 CustomValidator 控件 


自 定义 逻辑 验证 控件 (CustomValidator) ft Vr fi JH A 4E X AY 48 EE £6 6 dE Jo iE f fT o 
例如 ,可 以 创建 一 个 验证 控件 判断 用 户 输入 的 是 否 包 含 ”. ”号 ,示例 代码 如 下 : 


protected void CustamValidatorl ServerValidate (object source, ServerValidateEventArgs args) 


{ args.IsValid -args.Value.ToString () -Contains (".") ; // 设 置 验证 程序 ,并 返回 布尔 值 
} 
protected void Buttonl Click (object sender, EventArgs e) // 用 户 自 定义 验证 
{ 
if (Page.IsValid) // 判 断 是 否 验证 通过 
{ ”Labell.Text =" 验 证 通过 "; // 输 出 验证 通过 
} 
else 
{ ”Labell.Text =" 输 入 格式 错误 "; // 提 交 失 败 信息 


} 
} 


上 述 代 码 不 仅 使 用 了 验证 控件 自身 的 验证 ,也 使 用 了 用 户 自 定义 验证 ,运行 结果 如 
图 4.10 所 示 。 
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图 验证 控件 


从 CustomValidator 验证 控件 的 验证 代码 可 以 看 出 ,CustomValidator 验证 控件 可 以 在 
服务 器 上 执行 验证 检查 。 如 果 要 创建 服务 器 端的 验证 函数 , 则 处 理 CustomValidator 控件 
的 ServerValidate 事件 。 使 用 传人 的 ServerValidateEventArgs 的 对 象 的 IsValid 字段 来 设 
置 是 否 通过 验证 。 

而 CustomValidator 控件 同样 也 可 以 在 客户 端 实现 ,该 验证 函数 可 用 VBScript 或 
JScript 来 实现 ,而 在 CustomValidator 控件 中 需要 使 用 ClientValidationFunction 属性 指定 
与 CustomValidator 控件 相关 的 客户 端 验证 脚本 的 函数 名 称 进 行 控 件 中 的 值 的 验证 。 


4.7 小 结 
本 章 主 要 讲述 验证 控件 的 使 用 方式 ,如 何 对 于 页 面 中 的 控件 进行 有 效 性 验证 。 验 证 控 


件 的 使 用 会 对 用 户 填 人 的 信息 进行 有 效 性 验证 ,防止 用 户 填写 的 非法 数据 发 送 到 服务 器 端 ， 
也 防止 对 网 站 的 安全 带 来 威胁 。 


课 后 思考 问题 


1. 做 一 个 登录 页 面 ,在 页 面 中 加 入 验证 控件 对 登录 页 面 的 输入 框 进行 有 效 性 校 验 , 登 
录 页 面 如 图 4. 11 所 示 。 


会 员 名 : (可 包含 sz、0-9 和 下 划 线 ) 
EB 《至 少 包 含 6 个 字符 ) 
& &J(E 8) 
图 登录 页 面 
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2. 做 一 个 注册 页 面 ,在 页 面 中 加 入 验证 控件 对 注册 页 面 的 输入 框 进行 有 效 性 校 验 , 注 
册页 面 如 图 4. 12 所 示 。 
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第 5 章 ASP. NET 的 Web 应 用 程序 


本 章 要 点 

。 ASP. NET 应 用 程序 基础 。 

。 Global. asax 文件 的 使 用 。 

* Application 对 象 的 状态 管理 。 

* Session 对 象 的 状态 管理 。 

* Application 与 Session 对 象 的 使 用 。 
。 Cookie 的 处 理 。 


5.1 ASP. NET 应 用 程序 基础 


ASP. NET 应 用 程序 (Application) 是 指使 用 ASP. NET 技术 建立 的 Web 应 用 程序 ,这 
是 由 网 页 文件 组 成 .可 以 完成 特定 工作 的 应 用 程序 。 

事实 上 , 当 在 支持 ASP.NET 的 Web 服务 器 上 建立 虚拟 目录 后 ,就 是 在 此 目录 中 创建 
ASP.NET 的 Web 应 用 程序 。 


5.1.1 网 页 间 数 据 共享 的 基础 


网 页 间 的 数据 共享 是 Web 应 用 程序 能 够 正确 执行 的 关键 ,因为 HTTP 并 不 会 保留 客 
户 端的 用 户 状 态 ,用 户 可 以 通过 网 页 间 数 据 共 享 来 保留 用 户 信息 ,以 便 正 确 地 执行 Web 应 
用 程序 。 

1. Session 时 间 

ASP. NET 的 “Session 时间” 是 指 Web 应 用 程序 从 一 个 ASP. NET 网 页 跳 转 到 其 他 
ASP. NET 网 页 过 程 中 所 花费 的 时 间 。 

在 ASP.NET 中 使 用 System. Web. SessionState 命名 空间 的 类 来 管理 Session 时 间 的 
信息 ,也 就 是 建立 Session 对 象 来 保留 Session 时 间 的 数据 。 

2. 网 站 的 数据 共享 

当 用 户 进入 网 站 ,如 果 是 会 员 管 理 网 站 ,在 登录 后 可 以 获取 用 户 的 浏览 权限 ,但 是 服务 
器 端 并 不 知道 当前 客户 端 有 哪些 用 户 正 在 浏览 ,以 及 这 些 用 户 的 使 用 状态 ,因为 用 户 在 移 至 
其 他 网 站 时 ,用 户 登 录 数 据 并 不 会 自动 传 给 下 一 个 网 页 。 

不 仅 如 此 ,如 果 Web 网 站 同时 有 多 位 用 户 登 录 , 就 需要 考虑 网 站 的 数据 共享 ,主要 分 为 
两 种 。 

CD 共享 给 网 站 所 有 用 户 。 在 ASP. NET 程序 中 可 以 使 用 Application 变量 进行 共享 ， 
例如 当前 在 线 用 户 数 。 

(2) 每 位 用 户 的 专用 数据 。 在 ASP. NET 程序 中 可 以 使 用 Session 变量 进行 共享 ,例如 
登录 用 户 的 权限 。 

s ados 


虽然 ASP. NET 程序 声明 的 变量 无 法 跨越 不 同 的 ASP. NET 程序 ,但 是 服务 器 端 
Application 和 Session 对 象 建立 的 变量 , 却 可 以 让 不 同 的 ASP. NET 程序 进行 共享 数据 。 

其 目的 主要 是 为 了 让 用 户 在 浏览 网 站 的 过 程 中 ,可 以 保留 数据 以 便 其 他 ASP. NET 程 
序 能 够 正常 执行 。 


5.1.2 网 页 间 的 数据 传递 方法 


换个 角度 来 说 ,在 ASP. NET 程序 间 的 数据 传递 方法 就 是 如 何 保留 用 户 状态 的 方法 ， 
称 为 “状态 管理 "(State Management) 。 按 数据 存储 的 位 置 分 为 客户 端 和 服务 器 端 两 大 类 。 

1. 客户 端的 状态 管理 

客户 端的 状态 管理 是 将 数据 存储 在 用 户 计算 机 ,或 者 是 直接 存储 在 ASP. NET 程序 建 
立 的 网 页 中 ,如 表 5.1 所 示 。 


表 5.1 客户 端的 状态 管理 


状态 管理 方法 说 Hj 
Cookies Cookies 是 保留 在 用 户 计 算 机 上 的 小 文件 ,文件 内 容 是 一 些 用 户 信 息 
ViewState ViewState 功能 是 在 窗 体 回 发 时 能 够 在 网 页 中 使 用 ViewState 属性 保留 用 户 数据 
隐藏 字段 使 用 窗 体 隐 藏 字段 回 发 窗 体 数据 或 传递 数据 到 其 他 网 页 
QueryString 集合 对 象 | 使 用 网 址 URL 参数 , 即 在 URL 网 址 加 上 参数 ,将 数据 传递 给 其 他 网 页 


2. 服务 器 端的 状态 管理 
服务 器 端的 状态 管理 是 将 数据 存储 在 服务 器 计算 机 上 , 换 句 话说 , 它 会 占用 Web 服务 
器 的 系统 资源 ,如 表 5. 2 所 示 。 


表 5.2 服务 器 端的 状态 管理 


状态 管理 方法 说 明 
Application 对 象 使 用 Application 对 象 的 变量 存储 用 户 信息 
Session 对 象 使 用 Session 对 象 的 变量 存储 用 户 信 息 
数据 库 使 用 数据 库 的 记录 存储 用 户 信息 
XML 文件 或 文本 文件 使 用 XML 文件 或 文本 文件 存储 用 户 信 息 
Profile 对 象 使 用 HttpModules 类 的 Profile 对 象 存储 用 户 信息 


本 章 主 要 介绍 Application 和 Session 对 象 的 状态 管理 方法 。 


5.2 Global. asax 文件 的 使 用 

Global. asax 文件 是 Web 应 用 程序 的 系统 文件 ,属于 选项 文件 ,可 有 可 无 。 当 需要 使 用 
Application 和 Session 对 象 的 事件 处 理 程序 时 ,就 需要 创建 此 文件 。 

5.2.1 Global. asax 文件 的 结构 


ASP. NET 的 Global. asax 文件 是 ANSI 文本 文件 ,使 用 Windows 记事 本 就 可 以 编辑 
ecd x 


Global. asax 文件 中 的 内 容 。 

1. 创建 Global. asax 文件 

Visual Studio 就 可 以 创建 Global. asax 文件 。 建 立 网 站 后 , 右 击 网 站 名 称 , 选 择 “ 全 局 
应 用 程序 类 ”选项 (如 果 网 站 已 经 建立 就 不 会 看 到 此 项 目 ) ,如 图 5. 1 所 示 , 单 击 “ 添 加 ”按钮 
就 可 以 在 Web 网 站 中 建立 Global. asax 文件 。 一 个 Web 网 站 只 能 有 一 个 Global. asax 文 
件 , 并 且 文 件 名 不 能 改动 。 


D:\test\ 


Visual Studio 已 安装 的 模板 
Ere APRH 
E 


Bre 配置 文件 
国文 本 文件 
SQL 数据 库 数据 集 
F 加 站 点 地 图 es 报表 
$) VBScript 文件 本 移动 Yeb 窗 体 国 报 表 
JScript 文件 [Bab Yeb 用 户 控件 Qa xsur 文件 


im i 配置 文件 (got DEM 


图 "添加 新 项 ” 对话 杠 


2. Global. asax 文件 的 结构 
Global. asax 文件 主要 是 定义 Web 应 用 程序 的 Application, Start O , Application End O , 
Session Start O fll Session _End() 等 事件 处 理 程序 ,文件 结构 如 下 : 


<$@Application Language- "C£" $> 
«script runat= "server"> 
void Application Start (object sender, EventArgs e) 
{ /在 应 用 程序 启动 时 运行 的 代码 
} 
void Application End(object sender, EventArgs e) 
{ /在 应 用 程序 关闭 时 运行 的 代码 
} 
void Application Error (object sender, EventArgs e) 
{ /在 出 现 未 处 理 的 错误 时 运行 的 代码 
} 
void Session Start (object sender, EventArgs e) 
{ Z7 在 新 会 话 启动 时 运行 的 代码 
} 
void Session End (object sender, EventArgs e) 
{ /在 会 话 结束 时 运行 的 代码 
} 
</script> 
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Application 和 Session 对 象 的 事件 处 理 程序 如 表 5. 3 所 示 。 
表 5.3 Application 和 Session 对 象 的 事件 处 理 程序 


事件 处 理 程序 说 明 


当 第 1 位 用 户 进 入 ASP. NET 程序 时 ,Application_Start 事件 就 触发 ,触发 后 ,就 
Application_Start() | 算 有 成 千 上 万 位 用 户 进入 网 站 都 不 会 重新 触发 ,除非 Web 服务 器 关机 。 它 通常 
用 来 初始 化 Application 变量 ,例如 初始 化 访客 的 数量 


Application End() 当 Web 服务 器 关机 时 ,Application End 事件 就 会 触发 
当 用 户 建立 Session 时 间 时 ,就 触发 Session. Start 事件 ,如 果 有 50 位 用 户 , 就 触 


Session_Start() 发 50 次 事件 ,每 个 事件 是 独立 触发 的 ,不 会 相互 影响 ,通常 用 来 初始 化 用 户 专 用 
的 Session 变量 
当 用 户 在 默认 时 间 内 没有 进入 其 他 ASP. NET 程序 时 ,就 会 触发 此 事件 ,时 间 由 
Session_End() TimeOut 属性 设 定 ,通常 是 善后 用 途 的 程序 代码 ,例如 将 Session 变量 存 人 数据 
库 或 文本 文件 


注意 : 当 Web. config 文件 的 Sessionstate 模式 设置 为 InProc( 此 为 默认 值 ) 才 会 触发 
Session End 事件 ,如果 设 置 值 为 StateServer 或 SQLServer 就 不 会 触发 此 事件 。 


5.2.2 Global. asax 文件 的 使 用 


在 ASP.NET 的 Web 应 用 程序 中 使 用 Global. asax 文件 时 ,一 个 Web 应 用 程序 只 能 有 
唯一 的 Global. asax 文件 ,其 位 置 是 Web 应 用 程序 的 启动 点 目录 。 

1. Global. asax 事件 处 理 程序 的 执行 顺序 

当 用 户 请 求 ASP. NET 程序 后 ,就 会 替 每 位 用 户 建立 Session 时 间 和 Application 对 
象 ,接着 检查 ASP. NET 程序 是 否 含 有 Global. asax 文件 。 

WRA Global. asax 文件 ,就 将 它 编译 成 继承 HttpApplication 类 的 . NET Framework 
类 ,然后 在 执行 ASP. NET 文件 的 程序 代码 前 触发 Application_Start 事件 ,执行 Global. 
asax 文件 的 Application_Start() 事 件 处 理 程序 ,并 建立 Session 对 象 ,因为 Global. asax X 
件 存在 ,接着 执行 Session_Start() 事 件 处 理 程序 。 

当 Session 时 间 超 过 TimeOut 属性 的 设 定 值 (默认 为 20min) 或 执行 Abandon() 方 法 ， 
表示 Session 时 间 结 束 , 就 触发 Session_End() 事 件 执 行 处 理 程序 ,处 理 程序 是 在 关闭 
Session 对 象 前 执行 。 

如 果 Web 服务 器 关机 ,在 关闭 Application 对 象 前 就 会 执行 Application_End() 事 件 处 理 程 
序 ,当然 也 会 结束 所 有 用 户 的 Session 时 间 ,执行 所 有 用 户 的 Session _End() 事 件 处 理 程序 。 

2. ASP. NET 程序 : Global, asax 

在 Global. asax 文件 的 事件 处 理 程 序 中 建立 程序 代码 ,以 便 显示 事件 处 理 程 序 的 执行 
过 程 , 代 码 如 下 : 


«$8Application Language- "Cf" $5 
«script runat="server"> 
void Application Start (object sender, EventArgs e) 
( . Application["msg"] - "Application 开始 …<br/> "; 
} 
TE 


void Application End(object sender, EventArgs e) 


void Application Error (object sender, EventArgs e) 
t 
void Session Start (object sender, EventArgs e) 


{ Response.Write ("Session 时 间 开 始 …<br/>"); 
Response.Write ("Applcation 变量 的 值 为 : " +Application["msg"]); 


void Session End(object sender, EventArgs e) 
( Response.Write ("Session Hj |i] Zl 4i --- «br/» "); 


</script> 


3. ASP. NET 程序 : gloTest. aspx 
TE ASP. NET 程序 中 显示 整个 Global. asax 文件 的 事件 处 理 程序 的 执行 过 程 , 包 括 网 


页 请 求 事件 的 执行 顺序 ,代码 如 下 : 


< form id- "forml" runat="server"> 
«div» 
显示 Global.asax 文 件 中 的 内 容 <br/> 
</div> 
< /form» 


最 终 运行 结果 如 图 5. 2 所 示 。 


F elobal 测 试 - microsoeft Internet Explorer 


xig) REO 查看 W RAW IAT WHW | i 
QO (dA Gpr ve e| " 
HAED) fÆ) http://1ocalhost:1045/test/gloTest. aso] EJ P681 | EE > 


Session 时 间 开 始 

Applcation 变 量 的 值 为 ，Applcation 开始 

显示 Globalasax 文 件 中 的 内 容 zi 
RIS s: E 


图 文件 最 终 运 行 结果 


5.3 Application 对 象 的 状态 管理 


在 ASP.NET 程序 中 可 以 使 用 Application 和 Session 对 象 建立 变量 ,可 以 称 其 为 
Application 和 Session 变量 ,它们 可 以 用 来 存储 用 户 状 态 信息 的 共享 数据 。 


5.3.1 Application 对 象 基础 
Application 和 Session 对 象 的 目的 是 为 了 保留 用 户 状 态 , 以 便 ASP. NET 程序 能 够 顺 
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利 执行 ,其 差异 只 是 保留 变量 的 范围 不 同 。 

1. Application 对 象 

Application 对 象 可 以 建立 Application 变量 , 它 和 一 般 程 序 变 量 不 同 , Application 变量 
是 一 个 Contents 集合 对 象 , 此 变量 可 以 为 访问 网 站 的 每 一 位 用 户 提供 一 个 共享 数据 的 通 
道 ,因为 Application 变量 允许 网 站 的 每 位 用 户 获 取 或 更 改 其 值 。 

Application 对 象 是 在 第 一 个 Session 对 象 建立 后 建立 ,Application 对 象 的 范围 直到 
Web 服务 器 关机 或 所 有 的 用 户 都 离线 后 才 会 删除 。 

2. Application 对 象 的 使 用 

不 论 网 站 中 有 多 少 位 用 户 同时 浏览 网 站 ,在 服务 器 端 内 存 中 只 保留 一 份 Application 变 
量 , 其 变量 格式 如 下 : 


Application ["userid"]- 1234; 


上 述 程序 代码 将 userid 的 Application 变量 设置 为 1234, 此 变量 和 ASP. NET 程序 变 
量 不 一 样 , 它 是 获取 Contents 集合 对 象 的 元 素 , 变 量 名 称 是 字符 串 。Application 对 象 是 
System. Web 命名 空间 的 HttpApplicationState 类 ,其 常用 属性 如 表 5.4 所 示 。 


表 5.4 Application 对 象 的 常用 属性 


属性 说 明 
Contents 获取 HttpApplicationState 对 象 , 此 属性 是 为 了 和 旧版 ASP 兼容 
Count 获取 共有 和 多少 个 Application 变量 ,也 就 是 HttpApplicationState 集合 对 象 的 对 象 数 
Item 使 用 变量 名 称 或 索引 值 获取 Application 变量 值 


3. Application 对 象 状 态 管理 的 同步 

ASP. NET 应 用 程序 的 每 位 用 户 都 可 以 存 取 Application 变量 ,用 户 可 以 同时 读 取 
Application 变量 ,但 是 如 果 有 一 位 更 改 数 据 ,其 他 用 户 读 取 数据 时 ,就 会 发 生 数据 冲突 ,为 
了 避免 这 种 情况 ,需要 考虑 同步 问题 。 

在 Application 对 象 中 提供 LockC) 和 UnLock() 方 法 ,可 以 保证 在 同一 时 间 内 只 允许 一 
位 用 户 存 取 Application 变量 ,其 程序 代码 如 下 : 

Application.Lock(); 

Application ["usernum"] —-Application["usernum"] +1; 

Application.UnLock(); 

上 述 程序 代码 在 更 改变 量 前 执行 Lock() 方 法 避免 其 他 用 户 存 取 此 变量 ,如 果 读 取 就 不 
需要 Lock() 方 法 。 在 更 改 后 ,此 例 是 将 Application 变量 usernum 值 加 1 后, 即 可 使 用 
UnLock() 方 法 ,以 便 让 其 他 用 户 更 改 此 变量 。Application 对 象 的 常用 方法 如 表 5. 5 所 示 。 


表 5.5 Application 对 象 的 常用 方法 


5 法 说 明 
LockO 禁止 其 他 用 户 修改 Application 变量 
UnLockO 允许 其 他 用 户 修改 Application 变量 


* 45 « 


在 实际 操作 中 ,Application 变量 可 以 记录 登录 网 站 的 用 户 总 数 ,或 网 站 已 经 登录 的 用 
户 总 数 ,至 于 每 位 用 户 状态 则 使 用 Session 变量 记录 。 

5.3.2 网 站 的 访客 计数 

网 站 的 访客 计数 是 一 种 必 备 组 件 , 其 目的 是 显示 有 多 少 位 访客 曾经 浏览 网 站 ,显示 信息 
可 以 从 开 站 以 来 的 访客 数 ,或 一 段 时 间 内 的 访客 数 。 

ASP.NET 的 访客 计数 在 Global. asax 文件 的 Session_Start() 事 件 处 理 程序 中 ,使 用 


Application 变量 记录 访客 计数 ,具体 代码 如 下 : 
1. ASP. NET 程序 : Global. asax 


< $8&Application Language- "C£ " $» 
«script runat="server"> 
void Application Start (object sender, EventArgs e) 
{ // 初 始 化 访客 计数 的 Application 变量 
Application["visitedNum"] =0; 
) 
void Session Start (object sender, EventArgs e) 
{ Application.Iock(); 
// 来 了 一 位 用 户 计数 加 1 
Application["visitedNum"] =Application["visitedNum"] +1; 
Application.UnLock (); 
} 
</script> 


2. ASP. NET 程序 : showCount. aspx 


<div> 
<asp:Label ID= "Labell" runat="server" Text="">< /asp:Label» 
</div> 


3. ASP. NET 程序 : showCount. aspx. cs 


protected void Page Load(object sender, EventArgs e) 

{ Labell. Text =" 当 前 在 线 用 户 为 : " - Application["visitedNum"] .ToString () +" 位。 
} 

最 终 的 运行 结果 如 图 5. 3 所 示 。 


| EE TE CT - Microso ft Internet 了 xplorer [-|G[ x] 
| 文件 F) iio) SEV BEW IAT WHW | ea 


(Q7 -O- i9 3 | Der Wm e| G- " 
Hio) a http://localhost: 1045/test/shoxCount. aspx =| EJ S2 | iei > 


当前 在 线 用 户 为 ,4 位。 


[ES [-I-ECT- TC EERRmn 
图 显示 在 线 用 户 信息 
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5.4 Session 对 象 的 状态 管理 


对 于 Web 应 用 程序 的 用 户 数据 ,或 是 购物 车 购买 商品 等 个 人 专用 数据 ,并 不 是 使 用 
Application 对 象 ,而 是 使 用 Session 对 象 的 状态 管理 。 


5.4.1 Session 对 象 的 基础 


当 尚 未 建立 Session 时 间 的 用 户 浏览 Web 网 站 后 ,ASP. NET 的 Web 应 用 程序 就 会 为 
用 户 建立 Session 时 间 和 建立 对 应 的 Session 对 象 。 

1. Session 对 象 

每 一 个 Session 对 象 具有 唯一 的 Session ID 编号 ,在 整个 浏览 ASP. NET 应 用 程序 的 
过 程 中 (访问 不 同 ASP. NET 程序 时 ) ,都 可 以 存 取 Session 对 象 建立 的 变量 。 

在 ASP.NET 的 Web 应 用 程序 中 使 用 Session ID 编号 判断 用 户 是 否 仍 在 Session 时 
间 , 它 是 直接 到 Session 对 象 的 TimeOut 属性 设 定时 间 到 时 (默认 值 为 20min) ,或 执行 
Abandon() 方 法 后 才 会 结束 Session 时 间 。 不 过 ,用 户 每 次 执行 新 的 ASP. NET 程序 时 ， 
TimeOut 属性 都 会 归 零 重新 计算 ,所 以 除非 有 浏览 网 站 超过 TimeOut 属性 的 时 间 ,否则 用 
户 浏 览 网 站 时 间 都 属于 同一 个 Session 时 间 。 如 果 同 时 有 多 位 用 户 浏 览 网 站 ,每 位 用 户 都 
指定 不 同 的 Session ID 编号 ,存储 此 ID 的 Session 变量 只 允许 拥有 此 ID 的 用 户 存 取 ,其 他 
用 户 并 无 法 存 取 这 些 变量 。ASP. NET 的 Web 应 用 程序 在 同一 段 时 间 内 的 Session ID 编 
号 是 唯一 值 ,并 不 会 重复 ,但 是 不 能 使 用 Session ID 作为 数据 库 表 主 索引 ,因为 在 不 同时 间 ， 
用 户 可 能 指定 相同 的 Session ID。 

2. Session 变量 的 使 用 

Session 变量 是 用 户 的 专用 数据 ,虽然 每 位 用 户 的 Session 变量 名 称 相 同 ,但 是 值 可 能 
不 同 。 而 且 只 有 该 用 户 才能 存 取 自己 的 Session 变量 。 例 如 ,用 户 hueyan 登录 网 站 ,建立 
Session 变量 程序 代码 如 下 : 


Session ["username"]= "hueyan" 
Session ["password"]- "1234" 


上 述 程序 代码 的 Session 变量 使 用 字符 串 作 为 名 ,username 和 password 的 值 属于 用 户 
hueyan。 接 着 另 一 位 用 户 jane 也 登录 网 站 ,也 会 替 他 建立 一 组 Session 变量 ,其 程序 代码 
WTF: 


Session ["username"]= "jane" 


Session ["password"]= "4567" 


上 述 程序 代码 的 Session 变量 拥有 相同 名 称 , 只 是 值 不 同 ,因为 属于 不 同 用 户 的 Session 
变量 。 

3. Session 对 象 的 属性 和 方法 

Session 对 象 的 常用 方法 如 表 5. 6 所 示 。 

Session 对 象 的 常用 属性 如 表 5.7 所 示 。 
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表 5.6 Session 对 象 的 常用 方法 


方 法 说 明 
Abandon() 清除 用 户 建立 的 Session 变量 ,也 就 是 说 再 也 不 能 存 取 Session 变量 的 值 
Remove() 删除 指定 的 Session 变量 ,参数 是 Session 变量 的 名 称 字符 串 


表 5.7 Session 对 象 的 常用 属性 
属 性 说 明 


设 定 和 获取 超过 Session 时 间 的 时 间 , 从 第 1 次 进入 ASP. NET 程序 到 下 一 次 请 求 的 间隔 
时 间 ,以 分 钟 计 ,默认 值 为 20min 


SessionID | 获取 用 户 唯 一 的 Session 编号 ,此 为 只 读 属 性 
LCID 使 用 指定 区 域 码 的 设 定 , 包 含 日 期 时 间 和 货币 等 格式 


TimeOut 


5.4.2 目前 有 多 少 人 仍 在 线 


访客 计数 是 历史 记录 ,在 线 用 户 数 是 目前 的 实时 状态 ,如 果 想 知道 目前 有 多 少 位 用 户 停 
留 在 网 站 ,其 最 大 问题 是 如 何 判断 用 户 目 前 仍 在 线 , 可 以 指定 TimeOut 属性 以 停留 在 网 站 
多 久 时 间 来 判断 是 否 为 在 线 用 户 , 代 码 如 下 : 


Session.Timeout-5 


上 述 程序 代码 指定 值 是 分 钟 ,也 就 说 停留 Smin 的 用 户 算是 目前 在 线 用 户 ,不 过 ， 
Application_Start() 事 件 处 理 程序 并 不 能 指定 TimeOnut 属性 , 它 位 于 Session_Start() 事 件 
处 理 程 序 。 

注释 : 实际 上 ,判断 用 户 是 否 仍 在 线 是 一 件 困 难 的 工作 ,最 简单 的 方法 是 使 用 TimeOut 
属性 ,但 是 并 不 能 准确 计算 出 真正 仍 在 线 的 用 户 数 ,因为 TimeOut 属性 值 的 时 间 差 可 能 相 
差 数 分 钟 之 久 。 

1. ASP. NET 程序 : Global, asax 


«script runat="server"> 

void Application Start (object sender, EventArgs e) 

{  // 初 始 化 访客 计数 的 Application 变量 
Application["visitedNum"] =07 


void Session Start (object sender, EventArgs e) 

1 Session.Timeout =5; // 设 定 Session 时 间 是 多 少 分 钟 过 期 
Application.Lock(); 
// 来 了 一 位 用 户 计数 加 1 
Application["visitedNum"] = (Int32)Application["visitedNum"] +17 
Application.UnLock (); 

} 

void Session End (object sender, EventArgs e) 

{ Application.Lock(); 
// 走 了 一 位 用 户 计数 减 1 
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Application["visitedNum"] = (Int32)Application["visitedNum"] -1; 
Application.UnLock(); 

} 

</script> 


2. ASP. NET 程序 : showCount. aspx 

«div» 

<asp:Label ID= "Labell" runat="server" Text="">< /asp:Label» 

« /div» 

3. ASP. NET 程序 : showCount, aspx. cs 

protected void Page Load(object sender, EventArgs e) 

{ Labell.Text =" 当 前 在 线 用 户 为 : " Application["visitedNum"].ToString () +", "7 
} 


最 终 的 运行 结果 如 图 5. 4 所 示 。 
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5.5 Cookie 的 处 理 


在 使 用 ASP. NET 建立 Web 应 用 程序 时 ,要 保留 用 户 的 浏览 记录 ,例如 记录 用 户 是 否 
浏览 过 网 站 或 输入 的 相关 数据 ,因为 HTTP 并 不 会 保留 状态 ,Cookie 就 是 一 种 存储 信息 的 
好 方法 。 


5.5.1 Cookie 基础 


Cookie 可 以 解决 HTTP 无 法 保留 信息 的 问题 。 虽 然 用 户 可 以 使 用 文本 文件 .XML XC 
件 和 数据 库 来 存储 相关 数据 ,但 是 对 于 成 千 上 万 个 来 一 次 或 多 次 的 访客 而 言 ,存储 这 些 数据 
实在 太 浪费 硬盘 空间 ,Cookie 则 是 最 佳 的 解决 方案 。 

1. Cookie 存储 的 文件 来 

Cookie 存储 在 客户 端 ,也 就 是 浏览 程序 所 在 的 计算 机 ,所 以 并 不 会 浪费 服务 器 资源 ,只 
要 用 户 进 入 网 站 时 ,就 可 以 检查 客户 端 是 否 有 存储 Cookie, 通 过 Cookie 存储 信息 来 建立 复 
杂 的 Web 应 用 程序 。 

如 果 读 者 常常 浏览 Web 网 站 ,在 Windows XP 的 C:\Documents and Settings \ 
Administrator\Cookie X ff 3€ (Administrator 是 当前 用 户 名 称 ) 中 可 以 看 到 网 站 保留 的 

iA 


Cookie 文件 。 

2. Cookie 的 使 用 

Cookie 在 网 站 应 用 领域 相当 广泛 ,其 主要 目的 是 使 用 Cookie 来 保留 一 些 数据 ,如 下 所 示 。 

a) 个 人 信息 。Cookie 可 以 保留 个 人 信息 ,例如 姓名 、 地 址 、 时 区 、 账 号 和 是 否 曾 经 访问 
网 站 。 

(2) 个 性 化 的 信息 。Cookie 可 以 建立 个 性 化 网 站 外 观 和 个 人 喜好 的 网 站 内 容 , 或 者 提 
供用 户 有 兴趣 的 信息 。 

(3) 网 站 购物 车 。 在 线 购 物 车 需要 存储 用 户 选 购 的 商品 ,Cookie 也 可 以 用 来 记录 选 购 
商品 。 

3. Cookie 的 问题 

虽然 Cookie 可 以 帮助 用 户 建立 复杂 的 Web 应 用 程序 ,但 是 在 使 用 时 仍然 有 一 些 注意 
事项 ,如 下 所 示 。 

CD 浏览 程序 是 否 支 持 Cookie。 虽 然 Internet Explorer 和 Netscape 浏览 程序 都 支持 
Cookie ,不 过 在 Internet Explorer 4. 0 前 的 版 本 需要 设置 接受 Cookie. Internet Explorer 5. 0 
之 后 的 版 本 默认 接受 Cookie 且 用 户 无 法 更 改 ,不 过 ,仍然 有 少数 用 户 的 浏览 程序 并 不 支持 
Cookie, 

(2) Cookie 可 以 删除 。 因 为 Cookie 是 存储 在 客户 端的 计算 机 上 ,所 以 可 能 在 上 级 浏览 
程序 或 计算 机 软件 时 破坏 或 删除 Cookie 文件 。 

(3) Cookie 可 能 修改 。 因 为 Cookie 存储 在 客户 端的 计算 机 上 ,用 户 可 以 自己 修改 
Cookie 的 内 容 , 换 句 话说 ,不 可 以 使 用 Cookie 存储 重要 信息 。 

(4) Cookie 能 够 复制 。Cookie 文件 可 以 复制 ,当然 也 有 可 能 被 其 他 用 户 复制 。 


5.5.2 如 何 使 用 Cookie 

ASP. NET 中 通过 HttpCookie 类 来 设置 或 读 取 Cookie 的 值 。Cookie 值 的 设置 如 下 : 

HttpCookie cookie - new HttpCookie ("aspcn") ; 

上 面 的 代码 建立 起 一 个 名 为 aspcn 的 HttpCookie 实例 。 

建立 实例 后 ,将 给 其 赋值 。 在 一 个 Cookie 中 可 以 存储 一 个 值 ,也 可 以 存储 多 个 值 。 通 
过 设置 Cookie 的 Value 属性 值 ,可 以 在 Cookie 中 存储 一 个 值 ,代码 如 下 : 

Cookie.Value = "deidao"; 

通过 Cookie 的 Values 集合 ,可 以 在 同一 个 Cookie 中 存储 多 个 值 ,代码 如 下 : 


HttpCookie cookie=new HttpCookie ("aspcn"); 
Cookie.Values.Add ("username", "feidao"); 
Cookie.Values.Add ("password","123"); 


Values 集合 使 用 的 Add 方法 中 第 一 个 参数 为 关键 字 (Key) ,第 二 个 参数 是 设置 的 值 
(Value) 。 
设置 Cookie 的 最 后 一 步 是 通过 AppendCookie 方法 将 设置 的 Cookie 应 用 到 Response 
对 象 中 去 ,代码 如 下 : 
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Response.AppendCookie (cookie) ; 


至 此 ,一 个 简单 的 Cookie 设置 完毕 。 但 是 ,Cookie 的 功能 不 仅仅 只 是 这 么 简单 ,除了 
设置 其 值 外 ,还 可 以 设置 其 应 用 的 域 (Domain) 、 路 径 (Path)、 过 期 时 间 (Expires) 和 安全 
(Secure) 等 。 

设置 完 Cookie, 下 一 步 是 如 何 读 取 Cookie。 

读 取 Cookie, 首 先 需要 通过 Request 对 象 Cookies 集合 获取 目标 Cookie 的 对 象 实例 。 


HttpCookie readCookie- Request .Cookies ("aspcn") ; 


然后 再 根据 Cookie 中 存储 值 的 多 少 来 区 分 读 取 , 读 取 只 存储 一 个 值 的 Cookie, 通 过 读 
取 对 象 Cookie 的 Value 值 即 可 ,而 读 取 存储 有 多少 值 的 Cookie 则 读 取 Values 集合 中 的 关 
键 字 所 对 应 的 值 。 下 面 有 两 个 例子 分 别 演示 Cookie 存储 、 读 取 一 个 值 和 多 个 值 的 方法 ,并 
将 过 期 时 间 设 置 为 6min 以 后 。 

Cookie 中 只 存储 一 个 值 的 例子 如 下 。 

1. ASP. NET 程序 : cookieTest. aspx 


«div» 

<b> 演 示 设 置 一 个 Cookie 的 值 < /b» «br/» 

单个 Cookie 的 值 是 : <asp:Label ID= "show" runat="server" Text- "">< /asp:Label» 
</div> 


2. ASP. NET 程序 : cookieTest, aspx. cs 


protected void Page Load(object sender, EventArgs e) 
{  HttpCookie cookie - new HttpCookie ("aspcn") ; 
DateTime dt —- DateTime .Now; 
TimeSpan ts =new TimeSpan(0, 0, 6, 0); 
cookie.Expires =dt.Add (ts); 
cookie.Value ="feidao"; 
Response.AppendCookie (cookie) ; 
// 读 取 Cookie 
HttpCookie readCookie =Request .Cookies["aspcn"]; 
show.Text = readCookie.Value; 
} 


最 终 的 运行 结果 如 图 5.5 所 示 。 
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Cookie 存储 多 个 值 的 例子 如 下 。 
1. ASP. NET 程序 : cookieTest. aspx 


«div» 

<b> 演 示 设 置 多 个 Cookie 的 值 < /b» <br/> 

Cookiel 的 值 为 : «asp:Label ID= "showl" runat- "server" Text="">< /asp:Label> 
Cookie2 的 值 为 : «asp:Label ID= "show2" runat= "server" Text="">< /asp:Label> 
« /div» 


2. ASP. NET 程序 cookieTest, aspx. cs 


protected void Page Load(object sender, EventArgs e) 
(  HttpCookie cookie - new HttpCookie ("aspcn") ; 
DateTime dt — DateTime .Now; 
TimeSpan ts =new TimeSpan (0, 0, 6, 0); 
cookie.Expires =dt.Add (ts); 
//cookie.Value ="feidao"; 
cookie.Values.Add ("username", "feidao"); 
cookie.Values.Add("password", "123"); 
Response. AppendCookie (cookie); 
// 读 取 Cookie 
HttpCookie readCookie =Request .Cookies["aspcn"]; 
showl.Text = readCookie.Values ["username"].ToString(); 
show2.Text = readCookie.Values["password"].ToString(); 
} 


最 终 的 运行 结果 如 图 5.6 所 示 。 
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注意 这 两 个 程序 中 都 有 如 下 代码 : 


DateTime dt =DateTime .Now; 
TimeSpan ts =new TimeSpan (0, 0, 6, 0); 
cookie.Expires =dt.Add (ts); 


这 段 代 码 是 设置 过 期 时 间 最 常用 的 ,TimeSpan 类 构造 函数 中 4 个 参数 ,分 别 代 表 天 
(Day) .小 时 (Hour) ,分 钟 (Minute) 和 秒 (Second)。 最 后 使 用 Add 方法 产生 新 的 时 间 ,然后 
将 其 值 赋 给 Expires 属性 。 
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5.6 小 结 

本 章 主 要 介绍 了 Application 对 象 和 Session 对 象 的 使 用 方法 以 及 两 者 之 间 的 不 同 点 ， 
且 把 两 者 使 用 的 场合 做 了 具体 介绍 ,本 章 还 介绍 了 Cookie 对 象 的 使 用 ,以 及 何 时 使 用 
Cookie 比较 合适 等 方面 的 知识 。 


课 后 思考 问题 


l. Application 对 象 与 Session 对 象 的 区 别 是 什么 ?如何 使 用 这 两 个 对 象 ? 
2. Global. asax 页 面 的 作用 是 什么 ? 


第 6 章 ADO. NET 的 应 用 


本 章 要 点 

。 学 习 和 使 用 . NET 数据 提供 程序 。 

* 学 习 Connection 连接 对 象 的 使 用 。 

。 掌握 如 何 打开 和 关闭 数据 库 连接 。 

。 掌握 Command 命令 对 象 的 使 用 。 

* 使 用 DataReader 读 取 数 据 。 

。 使 用 DataSet 和 DataAdapter 对 象 查询 数据 。 


6.1 ADO.NET 对 象 模 型 


ADO. NET 是 微软 公司 . NET 框架 的 一 部 分 ,ADO. NET 类 库 位 于 System. Data 命名 
空间 下 ,由 一 组 工具 类 组 成 ,应 用 程序 可 以 很 轻松 地 借 此 与 基于 文件 或 基于 服务 器 的 数据 存 
储 进行 通信 和 管理 。 

ADO. NET 访问 数据 的 操作 是 建立 到 数据 源 的 连接 、 执 行 命令 以 及 获取 返回 的 结果 。 
同时 ,ADO. NET 提供 不 同 的 对 象 完 成 以 上 各 步 操作 ,如 图 6. 1 所 示 。 
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图 6. 1 中 涉及 的 ADO. NET 的 基本 对 象 如 表 6. 1 所 示 。 


表 6.1 ADO.NET 基本 对 象 描述 


对 象 描 述 
Connection 对 象 用 来 实现 与 数据 库 的 连接 
Command 对 象 用 来 对 数据 库 执行 SQL 语句 


。54 。 


对 象 描 述 
DataReader 对 象 从 数据 库 中 读 取 数 据 , 实 现 对 数据 源 的 只 读 访 问 
DataAdapter 对 象 把 来 自 特定 数据 源 的 信息 调整 为 关系 型 数据 格式 ,以 适应 DataSet 的 需要 
DataSet 对 象 ADO. NET 的 断 开 式 组 件 


6.2 Connection 对 象 


在 代码 中 要 想 对 数据 库 操作 就 必须 用 到 Connection 对 象 ,进行 对 数据 库 的 连接 。 
Connection 对 象 用 于 连接 到 数据 库 和 管理 对 数据 库 的 事务 。 

.NET 框架 支持 多 种 数据 提供 程序 : 根据 . NET Framework 提供 程序 的 不 同 ， 
Connection 对 象 分 为 4 种, 分别 是 OleDbConnection, SqlConnection, OdbcConnection 和 
OracleConnection。 相 应 的 其 他 对 象 也 分 别 包括 4 种 不 同 前 级 的 对 象 。 

OleDbConnection 对 象 使 用 OLEDB, 任 何 OLEDB 提供 程序 都 能 使 用 OLEDB, 包 括 SQL 
Server。 但 是 SqlConnection 对 象 只 能 被 SQL Server 使 用 。 这 里 主要 介绍 SqlConnection 
类 ,其 他 的 用 法 跟 SqlConnection 类 类 似 。 

(1) 在 使 用 ADO. NET 对 象 的 时 候 在 . cs 文件 中 先 把 命名 空间 导入 。 使 用 OLEDB 接 
口 时 导入 System. Data. OleDB 命名 空间 ,使 用 SQL Server 时 导入 System. Data. SqlClient 
命名 空间 。 

(2) 把 跟 数据 库 连 接 的 连接 字符 串 写 好 。 下 面 分 别 是 连接 Access 数据 库 和 SQL 
Server 数据 库 的 连接 字符 串 。 

连接 Access 数据 库 : 

string strConn - "Provider-Microsoft.Jet.OLEDB.4.0; Data Source=" +Server.MapPath ("~ \\App_ 

Data\\userinfo.mdb "); 


连接 SQL Server 数据 库 : 

string strConn =" server- (local);Database- login;uid- testSa;pwd- 123; "; 
(3) 连接 字符 串 建 好 后 ,建立 连接 对 象 : 

SqlConnection myConn - new SqlConnection (strConn); 


(4) 建立 了 连接 对 象 ,使 用 Open 方法 把 连接 对 象 打开 ,就 建立 好 了 跟 数据 库 的 连接 。 


myConn.Open (); 

O) 在 使 用 完 连 接 对 象 时 ,用 Close 方法 把 连接 对 象 关闭 。 
建立 连接 对 象 的 具体 代码 如 下 : 

using System.Data.SqlClient; // 命 名 空间 的 引入 


public partial class testConn : System.Web.UI.Page 
{ protected void Page Load(object sender, EventArgs e) 
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string strConn ="server= (local);Database- task;uid= test;pwd= 123"; 

// 建 立 连接 对 象 

SqlConnection myConn =new SqlConnection (strConn); 

try 

{ myConn.Open(); // 用 open 方 法 打开 跟 数据 库 的 连接 
Response.Write ("数据 库 连接 成 功 !"); 

} 

catch (Exception ex) 

{ Response.Write ("数据 库 连接 失败 1") ; 
Response.Write (ex.Message); 

} 

myConn .Close () 7 // 使 用 完毕 用 close 方 法 关闭 跟 数据 库 的 连接 


} 
上 述 是 典型 的 数据 库 连 接 代码 ,对 于 存放 数据 库 的 连接 信息 ,还 可 以 有 另外 的 两 种 


方法 。 


在 这 


的 


方法 一 % 
将 数据 库 连 接 字符 串 存放 在 应 用 程序 的 配置 文件 (web. Config) 中 ,代码 如 下 : 


<connectionstrings> 
< add name-"strConnl" connectionString- "Data Source- .VSQLEXPRESS; Initial Catalog= 
task;User ID-test; Password- 123;" providerName- "System.Data.SqlClient" /» 


< /connectionStrings» 
这 样 在 . cs 文件 中 取 字 符 串 改 写 如 下 : 


string constr =System.Configuration.ConfigurationManager.ConnectionStrings 


["strConnl"].ConnectionString; 

方法 二 : 

将 数据 库 连 接 字符 串 存 放 在 新 建 的 一 个 类 的 方法 中 ,例如 可 将 此 类 命名 为 MyClass ,并 
个 类 中 编写 如 下 代码 : 


public class MyClass 
(private static string strSql = "Data Source- .\SQLEXPRESS; Initial Catalog-task; 
User ID-test;Password- 123;"; 
public string strCon 
t 
get( return (strSqgl); } 


) 
在 引用 此 数据 库 连 接 信息 时 ,首先 要 在 应 用 程序 中 创建 一 个 新 类 ,然后 再 调用 这 个 类 中 


属性 方法 。 
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MyClass classl =new MyClass (); 
SqlConnection conn =new SqlConnection (classl.strCon); 
conn.Open() ; 


conn.Close(); 


以 上 两 种 方法 连接 字符 串 的 重用 率 高 ,并 且 对 于 系统 以 后 的 维护 带 来 方便 。 建 议 使 用 


后 两 种 方法 来 建立 跟 数据 库 的 连接 。 


6.3 Command 对 象 


6.3.1 创建 Command X1 & 


在 连接 好 数据 源 后 ,就 可 以 对 数据 源 执行 一 些 命令 操作 。 命 令 操作 包括 从 数据 库 中 检 
索 或 者 对 数据 库 进行 插入 ,更 新 .删除 操作 。 在 ADO. NET 中 ,对 数据 库 的 命令 操作 通过 
Command 对 象 来 实现 。 

创建 Command 对 象 的 方法 : 


SqlCommand command =new SqlCommand (strSQL, conn); 


参数 代表 的 意义 如 下 。 

(1) strSQL: 可 以 是 SQL 语句 也 可 以 是 存储 过 程 。 
(2) Conn 是 创建 好 的 连接 对 象 。 

也 可 以 这 样 创建 Command 对 象 : 


SqlCommand comm =new SqlCommand () ; 
comm.Connection =conn; // 指 定 Command 对 象 的 连接 对 象 是 conn 
comm.CommandText = strSQL; // 指 定 Command 对 象 的 执行 语句 是 strsoL 


这 两 种 方法 起 到 的 作用 一 样 ,都 是 来 创建 Command 对 象 。 
6.3.2 执行 Command X1 & 


创建 好 Command 对 象 就 要 使 用 方法 来 执行 SQL 语句 或 者 存储 过 程 。Command 对 象 
包括 3 个 执行 方法 ,如 表 6. 2 所 示 。 


表 6.2. Command 对 象 常用 方法 及 说 明 


方 法 说 明 
ea 执行 SQE 语句 并 返回 受 影响 的 行 数 ,使 用 在 insert, update, delete 语句 中 ,返回 
值 为 一 1 说 明 操作 不 成 功 
ExecuteScalar 执行 查询 ,并 返回 查询 所 返回 的 结果 集中 第 一 行 的 第 一 列 。 忽 略 其 他 列 或 行 , 在 
使 用 count、sum、avg 等 统计 的 时 候 用 得 多 
ExecuteReader 执行 返回 数据 集 的 select 语句 


6.3.3 Command 对 象 实现 添加 功能 


本 案例 是 向 数据 库 students 的 userInfo 表 中 添加 一 条 新 记录 ,数据 库 中 userInfo 的 表 
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结构 如 下 。 

COD id: 用 户 的 序列 号 , 表 的 主键 ,自动 增长 类 型 。 

(2) username: 用 户 名 ,字符 串 类 型 。 

G) pwd: 密码 ,字符 串 类 型 。 

在 网 站 中 添加 一 个 user_add. aspx 页 面 , 页 面 上 添加 两 个 文本 框 ,它们 的 ID 分 别 是 
username 和 pwd, 最 终 显示 如 图 6. 2 所 示 。 


添加 信息 - windows Internet Explorer =|D|x| 
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图 添加 信息 的 主页 面 


user. add. apx 页 面 的 代码 如 下 : 


<table> 
<tr><td> 用 户 名 : «/ta» 
<td><asp:TextBox ID= "username" runat= "server"> < /asp:TextBox>< /td> 
</tr> 
<tr><td> 密 码 : < /td> 
<td><asp:TextBox ID= "pwd" runat- "server" TextMode- "Password">< /asp:TextBox> </ 
td> 
</tr> 
<tr><td><asp:Button ID- "Buttonl" runat="server" Text=" 添 加" onclick= 
"Buttonl Click" /></td> 
«td»«asp:Label ID= "Labell" runat="server" Text="">< /asp:label»« /td> 
</tr> 
</table> 


user. add. aspx. cs 页 面 的 代码 如 下 : 


using System.Data.SqlClient; // 注 意 要 把 命名 空间 加 入 
public partial class user add : System.Web.UI.Page 
{ protected void Page Load(object sender, EventArgs e) 
t 
} 
protected void Buttonl Click (object sender, EventArgs e) 
{ string usernamel —-username.Text; 
string pwdl -pwd.Text; 
string strConn =@"server= .NSQLEXPRESS; Database- students; uid- test;pwd- 123"; 
SglConnection con - new SqlConnection (strConn); 
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) 


con.Open () ; // 打 开 数 据 库 的 连接 
string strAdd =@"insert into userInfo (username,pwd) values ('" -usernamel + 
"y epadl e"; 
SqlCommand com - new SqlCommand (strAad, con) ; 
int i —com.ExecuteNonQuery () ; 
if (i >0) 
{ 
Labell.Text =" 添 加 成 功 !"; 
} 
else 
{ 
Labell.Text =" 添 加 失败 1"; 
} 
con.Close(); 


在 这 个 例子 中 ,执行 insert into 语句 时 ,使 用 的 是 Command 对 象 的 ExecuteNonQuery 
方法 , 当 ExecuteNonQuery 方法 执行 完 后 ,会 返回 一 个 影响 行 数 的 整 型 变量 ,可 以 根据 返回 
的 整 型 变量 来 检验 是 否 添加 成 功 。 


6.3.4 参数 查询 


正如 6. 3. 3 节 讲 述 的 插入 数据 的 时 候 , 用 到 了 insert 语句 "insert into userInfo (username, 
pwd) values(" 十 usernamel 十 "…" + pwdl + ")", 给 username 和 pwd 这 两 列 赋值 时 ， 
values 后 面 的 语句 非常 烦琐 ,并 且 这 样 写 也 很 不 安全 ,有 SQL 注入 的 危险 。 为 了 解决 这 些 
问题 可 以 使 用 参数 查询 。 

user add. aspx. cs 页 面 的 代码 修改 如 下 : 


protected void Buttonl Click(object sender, EventArgs e) 


t 


string usernamel —username.Text; 
string pwdl -pwd.Text; 
string strConn =@"server= .NSQLEXPRESS; Database- students; uid- test;pwd- 123"; 


SqlConnection con =new Sql1Connection (strConn); 


con.Open () ; // 打 开 数 据 库 的 连接 

string strSql -G"insert into userInfo (username,pwd) values (@name, @pwd) "; 
//ename 代表 参数 查询 

SqlCommand com = new SqlCommand (strSql, con); // 创 建 command 对 象 


com. Parameters .Add ("Gname", SqlDbType.NVarChar, 50); 

// 把 ename 添加 到 Command 对 象 的 参数 集合 中 
com. Parameters .Add ("@pwd", Sql1DbType.NVarChar, 50); 

// 把 apwda 添 加 到 Command 对 象 的 参数 集合 中 
com. Parameters ["@name"] .Value —-usernamel; // 给 参数 赋值 
com.Parameters ["@pwd"] .Value =pwdl; // 给 参数 赋值 
int i —com.ExecuteNonQuery () ; 
if (i >0) 
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{ Labell.Text =" 添 加 成 功 !"; 
} 

else 

{ Iabell.Text =" 添 加 失败 !1"; 
} 

con.Close(); 


H 


以 上 代码 的 解释 如 下 。 

1. 参数 的 SQL 命令 字符 串 

使 用 参数 查询 的 时 候 , 只 需要 把 SQL 语句 改写 为 insert into userInfo (username, pwd) 
values(@name,@pwd) 即 可 。 这 是 以 @ 符 合 开 头 的 字符 串 名 称 。 

2. 建立 Parameter 参数 对 象 

Parameter 参数 需要 用 Command 对 象 中 的 Parameter 对 象 的 Add() 方 法 添加 到 
Parameter 集合 中 。 代 码 如 下 : 


com. Parameters .Add ("@name", SqlDbType.NVarChar, 50); 
第 一 个 参数 "@name" 是 参数 名 称 , 第 二 个 参数 SqlDbType. NVarChar 是 数据 类 型 ,第 
三 个 参数 50 是 字段 大 小 。 
Paramter 参数 的 数据 类 型 属于 OleDbType 或 SalDbType 类 ,可 以 对 应 数据 库 字 段 的 
数据 类 型 。 常 用 数据 类 型 如 表 6. 3 所 示 。 
表 6.3 Parameter 参数 的 数据 类 型 


数据 类 型 说 明 对 应 的 . NET 的 数据 类 型 
Boolean 布尔 值 Boolean 

Integer 32 位 整数 Int32 

BigInt 64 位 整数 Int64 

Binary 二 进 制 数据 流 Byte 数组 
Currency 货币 值 Decimal 

Date 日 期 时 间 数 据 DataTime 
VarChar 不 定 长 度 的 非 Unicode 字符 串 String 


3. 指定 参数 SQL 命令 的 参数 值 
下 面 给 每 个 参数 指定 相应 的 值 就 可 以 了 ,代码 如 下 : 


com. Parameters ["@name"] .Value =usernamel; // 给 参数 赋值 


6.3.5 Command 对 象 实现 更 新 功能 


数据 表 中 的 数据 如 果 有 变更 ,例如 用 户 密码 改变 ,邮件 的 变更 等 ,这 就 需要 更 新 数据 就 
行 了 ,不 需要 新 添加 一 条 记录 。 
本 案例 向 数据 库 students 的 userInfo 表 中 更 新 一 条 新 记录 ,数据 库 中 userInfo 的 表 结 
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构 如 下 。 

O) id; 用 户 的 序列 号 , 表 的 主键 ,自动 增长 类 型 。 

(2) username: 用 户 名 ,字符 串 类 型 。 

(3) pwd: 密码 ,字符 串 类 型 。 

在 网 站 中 添加 一 个 user_update. aspx 页 面 ,页 面 上 添加 3 个 文本 框 ,它们 的 ID 分 别 是 
username、pwd 和 repwd ,最终 显示 如 图 6. 3 所 示 。 


于 更 新 信息 - Wicrosoft Internet Explorer [- [nf] 
xo) 编辑 EF) SEV KEN IAM 8" PF 


Qs -O-ha coss ij 
地 址 0) a http://localhost:1062/test/17] EJ 9638 | iit > 


E 更 新 数据 页 面 


user update. apx 页 面 的 代码 如 下 : 


<div> 
用 户 名 : <asp:TextBox ID= "username" runat- "server">< /asp:TextBox><br /> 
密 &nbsp; li]: <asp:TextBox ID= "pwd" runat="server" TextMode- "Password"> 
</asp:TextBox><br /> 
修改 密码 : «asp:TextBox ID= "repwd" runat- "server" TextMode- "Password"> 
< /asp:TextBox> <br /> 
<asp:Button ID- "Buttonl" runat="server" Text= "ffi iÀ " OnClick-"Buttonl Click" /> 
<asp:Label ID- "Labell" runat- "server"> < /asp:Label» 

</div> 


user update. aspx. cs 页 面 的 代码 如 下 : 


protected void Buttonl Click (object sender, EventArgs e) 
{ // 建 立 跟 数据 库 的 连接 
string strConn =@"Data Source- .\SQLEXPRESS; Initial Catalog- students; 
Integrated Security- True"; 
SqlConnection con - new SqlConnection (strConn); 
con.Open () ; 
// 建 立 Command 对 象 实现 update 
string strSql = "update [userInfo] set pwd- '" + repwd. Text + "' where username- '" + 
username.Text -"' and pwd- '" * pwd.Text &"'"; 
SqlCommand com - new SqlCommand (strSql, con); 
int i »com.ExecuteNonQuery () ; 
if (i20) 
{ Labell.Text =" 更 新 数据 成 功 !"; 
} 
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else 
{ Labell.Text =" 更 新 数据 失败 1n; 
} 


con.Close(); 


6.3.6 Command 对 象 实现 删除 功能 


对 于 数据 表 中 不 再 需要 的 记录 ,可 以 使 用 SQL 的 delete 命令 来 删除 数据 表 的 记录 
数据 。 

本 案例 向 数据 库 students 的 userInfo 表 中 根据 输入 的 用 户 名 删除 记录 。 

在 网 站 中 添加 一 个 user delete. aspx 页 面 , 页 面 上 添加 一 个 文本 框 , 它 的 ID 是 
username, 最 终 显示 如 图 6.4 所 示 。 
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E 删除 数据 页 面 


user. delete. apx 页 面 的 代码 如 下 : 


<div> 
用 户 名 : <asp:TextBox ID= "username" runat= "server">< /asp:TextBox> <br /> 
«asp:Button ID-"Buttonl" runat="server" OnClick-"Buttonl Click" Text-" 删除 数据 " 
OnClientClick- "return confirm(' 你 确实 要 删除 吗 ?');" /> 
«asp:Label ID- "Labell" runat= "server">< /asp:Label> 
</div> 


user delete. aspx. cs 页 面 的 代码 如 下 : 


protected void Buttonl Click(object sender, EventArgs e) 

{ // 建 立 跟 数据 库 的 连接 
string strConn =@"Data Source- .\SQLEXPRESS; Initial Catalog- students; 
Integrated Security- True"; 
SqlConnection con =new SglConnection (strConn); 
con.Open() ; 
// 建 立 Command 对 象 实现 delete 
string strSql = "delete from [userInfo] where username- '" +Username.Text +"'"; 
SqlCommand com =new SqlCommand(strSql, con); 
int i -com.ExecuteNonQuery () ; 
if (i >0) 
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{ Labell.Text =" 删 除数 据 成 功 !"; 


{ Labell.Text =" 删 除数 据 失败 !"; 
} 


con.Close(); 


6.4 DataSet 


6.4.1 DataSet 的 数据 库 操 作 


DataSet 是 ADO. NET 的 中 心 概念 。 可 以 把 DataSet 当成 内 存 中 的 数据 库 ,DataSet 是 
不 依赖 于 数据 库 的 独立 数据 集合 。 所 谓 独立 ,就 是 说 ,即使 断 开 数据 链 路 ,或 者 关闭 数据 库 ， 
DataSet 依然 是 可 用 的 ,DataSet 在 内 部 是 用 XML 来 描述 数据 的 ,由 于 XML 是 一 种 与 平台 
无 关 .与 语言 无 关 的 数据 描述 语言 ,而 且 可 以 描述 复杂 关系 的 数据 ,比如 父子 关系 的 数据 ,所 
以 DataSet 实际 上 可 以 容纳 具有 复杂 关系 的 数据 ,而 且 不 再 依赖 于 数据 库 链 路 。 


6.4.2 ADO. NET 的 DataSet 数据 模型 


因为 DataSet 可 以 看 作 是 内 存 中 的 数据 库 , 因 此 可 以 说 DataSet 是 数据 表 的 集合 , 它 可 
以 包含 任意 多 个 数据 表 (DataTable) ,而 且 每 一 DataSet 中 的 数据 表 (DataTable) 对 应 一 个 
数据 源 中 的 数据 表 (Table) 或 是 数据 视图 (View)。 数 据 表 实质 上 是 由 行 (DataRow) 和 列 
(DataColumn) 组 成 的 集合 ,目的 是 为 了 保护 内 存 中 数据 记录 的 正确 性 ,避免 并 发 访问 时 的 
读 写 冲突 ,DataSet 对 象 中 的 DataTable 负责 维护 每 一 条 记录 ,分 别 保存 记录 的 初始 状态 和 
当前 状态 。 从 这 里 可 以 看 出 ,DataSet 与 只 能 存放 单 张 数据 表 的 Recordset 是 截然 不 同 的 
概念 。 

DataSet 对 象 结构 是 非常 复杂 的 ,在 DataSet 对 象 的 下 一 层 中 是 DataTableCollection 对 
象 .DataRelationCollection 对 象 和 ExtendedProperties 对 象 。 前 面 已 经 说 过 ,每 一 个 
DataSet 对 象 是 由 若干 个 DataTable 对 象 组 成 。DataTableCollection 就 是 管理 DataSet 中 
的 所 有 DataTable 对 象 。 表 示 DataSet 中 两 个 DataTable 对 象 之 间 的 父子 关系 是 
DataRelation 对 象 。 它 使 一 个 DataTable 中 的 行 与 另 一 个 DataTable 中 的 行 相关 联 , 这 种 
关联 类 似 于 关系 数据 库 中 数据 表 之 间 的 主键 列 和 外 键 列 之 间 的 关联 。 
DataRelationCollection 对 象 就 是 管理 DataSet 中 所 有 DataTable 之 间 的 DataRelation 关系 
的 。 在 DataSet 中 DataSet, DataTable 和 DataColumn 都 具有 ExtendedProperties 属性 。 
ExtendedProperties 其 实 是 一 个 属性 集 (PropertyCollection) ,用 以 存放 各 种 自 定义 数据 ,如 
生成 数据 集 的 select 语句 等 。DataRow 表示 DataType 中 实际 的 数据 ,通过 DataRow 将 数 
据 添 加 到 用 DataColumn 定义 好 的 DataTable, 


6.4.3 DataSet 对象 的 三 大 特性 


(1) 独立 性 。DataSet 独立 于 各 种 数据 源 。 
RE 


(2) 离线 ( 断 开 ) 和 连接 。 
(3) DataSet 对 象 是 一 个 可 以 用 XML 形式 表示 的 数据 视图 ,是 一 种 数据 关系 视图 。 


6.4.4 DataSet 对 象 的 数据 库 操 作 


DataSet 对 象 的 数据 库 操作 需要 先 将 数据 填 人 DataTable 对 象 , 再 次 强调 ,DataSet 对 
象 处 理 的 对 象 是 保存 在 内 存 的 记录 数据 。 在 完成 记录 的 插入 、 删 除 和 更 新 后 ,记得 使 用 
DataAdapter 对 象 更 新 真正 的 数据 表 记 录 数 据 。 

如 同 SQL 命令 操作 步骤 ,同样 可 以 使 用 Connection 对 象 来 建立 数据 库 连接 ,其 建立 步 
又 如 下 。 

步骤 一 : 建立 Connection 对 象 。 

ASP. NET 程序 需要 使 用 Connection 对 象 来 建立 数据 库 连 接 , 语 句 如 下 : 


SqlConnection con =new SqlConnection (strConn); 


上 述 程序 代码 建立 con 的 数据 库 连 接 对 象 。 

步骤 二 : 建立 DataAdapter 和 CommandBuilder 对 象 。 

DataSet 对 象 是 使 用 DataAdapter 对 象 来 获取 记录 数据 , 它 是 DataSet 和 Connection 对 
象 数据 源 间 的 桥梁 ,可 以 获取 DataSet 的 记录 数据 和 更 新 数据 源 的 记录 数据 。 

建立 DataAdapter 对 象 的 步骤 如 下 : 


string strSql = "select * from userInfo"; 
SqlDataAdapter da - new SqlDataAdapter (strSql, con); 


上 述 程序 代码 建立 DataAdapter 对 象 ,第 一 个 参数 是 SQL 查询 命令 ,第 二 个 参数 是 
Connection 对 象 。 

注意 : Connection 对 象 一 般 是 以 Open() 方 法 打开 数据 库 连 接 后 才 可 以 使 用 
DataAdapter 对 象 来 使 用 它 , 不 过 建立 DataAdapter 对 象 可 以 省 略 Open() 方 法 。 例 如 ,上 
述 程 序 代 码 就 没有 使 用 Open() 方 法 ,而 是 直接 使 用 Connection 对 象 的 参数 来 建立 
DataAdapter 对 象 。 

DataAdapter 对 象 提 供 4 个 属性 , 即 SelectCommand InsertCommand, DeleteCommand 
和 UpdateCommand ,可 以 分 别 指定 查询 、 插 入 、 删 除 和 更 新 SQL 命令 的 Command 对 象 ,可 
以 使 用 CommandBuilder 对 象 来 自动 建立 SQL 命令 : 


SqiCommandBuilder cb =new SqlCommandBuilder (da) ; 


上 述 程序 代码 以 DataAdapter 为 参数 建立 CommandBuilder 对 象 ,此 对 象 可 以 配合 
DataSet 对 象 , 当 修改 DataSet 对 象 数据 后 ,自动 产生 数据 表 所 需 的 SQL 命令 , 即 前 面 所 介 
绍 的 SelectCommand, InsertCommand, DeleteCommand 和 UpdateCommand 属性 值 的 
Command 对 象 。 

步骤 三 : 建立 DataSet 对 象 填 人 记录 数据 。 

现在 可 以 建立 DataSet 对 象 并 且 执 行 DataAdapter 的 SQL 查询 命令 ,将 记录 数据 填 人 
DataSet 对 象 : 


DataSet ds =new DataSet (); 
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da.Fill (ds, "UserInfo"); 


上 述 程序 代码 建立 DataSet 对 象 后 ,使 用 DataAdapter 对 象 的 Fill() 方 法 将 SQL 命令 
的 查询 结果 填 人 第 一 个 参数 的 DataSet 对 象 。 

DataSet 对 象 是 由 多 个 DataTable 对 象 组 成 , 换 句 话说 ,Fill() 方 法 可 以 建立 DataSet 对 
象 的 DataTable 对 象 ,第 二 个 参数 UserInfo 是 DataTable 的 别名 ,之 后 可 以 使 用 此 名 称 , 它 
是 在 DataSet 对 象 中 获取 指定 的 DataTable 对 象 。 

步骤 四 : 在 DataTable 中 执行 数据 库 操作 。 

DataSet 对 象 的 每 一 个 DataTable 对 象 是 对 应 数据 库 的 一 个 数据 表 , 当 建立 好 DataSet 
对 象 填 人 记录 数据 后 ,就 可 以 在 DataTable 对 象 中 插入 、 删 除 和 更 新 行 对 象 DataRow, 这 是 
一 条 记录 。 

步骤 五 : 更 新 数据 表 的 记录 数据 。 

在 DataTable 对 象 中 插入 、 更 新 或 删除 DataRow 对 象 后 ,因为 操作 是 针对 保存 在 内 存 
的 DataSet 对 象 ,最 后 还 需要 更 新 数据 源 的 记录 数据 ,语句 如 下 : 


int count =da.Update (ds, "UserInfo"); 


上 述 程序 代码 使 用 DataAdapter 对 象 的 Update O 7r i 8 3r DataSet 对 象 ,因为 已 经 建 
立 CommandBuilder 对 象 ,在 更 新 前 ,DataAdapter 对 象 会 检查 此 对 象 ,CommandBuilder 对 
象 按照 DataTable 更 新 记录 ,自动 建立 DataAdapter 对 象 所 需 的 SQL 命令 来 更 新 数据 源 的 
记录 数据 。 

步 又 六 : 关闭 数据 库 连 接 。 

最 后 关闭 数据 库 连接 ,即使 用 Connection 对 象 的 Close() 方 法 关闭 ,语句 如 下 : 


con.Close(); 


6.4.5 DataSet 对 象 实现 插入 操作 


DataSet 对 象 插入 新 记录 操作 是 针对 DataTable 对 象 ,插入 记录 就 是 新 添加 DataRow 
对 象 ,语句 如 下 


DataRow newdr —ds.Tables["UserInfo"].NewRow(); 


上 述 程 序 代码 使 用 UserInfo 别名 获取 指定 的 DataTable 对 象 后 ,使 用 NewRow O77 iE 
新 添加 一 行 ,接着 可 以 输入 字段 值 ,语句 如 下 : 


newdr ["username"]- usernamel; 


newdr["pwd"] —pwdl; 


上 述 程序 代码 指定 字段 值 ,参数 字符 串 为 字段 名 称 ,字段 值 是 Web 控件 TextBox 的 
Text 属性 值 。 最 后 将 DataRow 对 象 添 加 到 DataTable 对 象 , 语 句 如 下 : 


ds.Tables ["userInfo"].Rows.Add (newdr) ; 


上 述 程序 代码 使 用 DataTable 的 Rows 属性 获取 DataRowCollection Xf £ (DataTable 
对 象 是 每 一 个 DataRow 对 象 的 集合 对 象 ) ,然后 使 用 DataRowCollection 对 象 的 Add() 方 法 
S BB. Y 


将 新 添加 的 一 行 添 加 到 DataTable 的 DataRowCollection XJ Z 。 


user add. apx 页 面 的 代码 如 下 : 


<table> 
«tr» 
«td» Jl P4: </td> 
«td»«asp:TextBox ID= "username" runat- "server" « /asp:TextBox»« /td» 
</tr> 
<tr><td> 密 码 : < /td> 
<td><asp:TextBox ID= "pwd" runat- "server" TextMode- "Password"» 
< /asp:TextBox» < /td> 
«/tr» 
«tr» 
«td» «asp:Button ID- "Buttonl" runat="server" Text- "if JII" onclick- 
"Buttonl Click" />< /td» 
«td»«asp:Label ID- "Labell" runat="server" Text="">< /asp:Label»« /td> 
</tr> 
</table> 


user. add. aspx. cs 页 面 的 代码 如 下 : 


protected void Buttonl Click (object sender, EventArgs e) 
{ string usernamel -username.Text; 
string pwdl -pwd.Text; 
string strConn =@"server= .NSQLEXPRESS; Database- students; Integrated Security- True"; 
SqlConnection con =new Sql1Connection (strConn) ; 
con.Open () ; // 打 开 数 据 库 的 连接 
string strSql = "select * from userInfo"; 
SqlDataAdapter da - new SqlDataAdapter (strSql, con); 
SqiCommandBuilder cb =new SqlCommandBui der (da) ; 
DataSet ds =new DataSet () 7 
da.Fill (ds, "userInfo"); 
// 添 加 一 行 
DataRow newdr =ds.Tables ["userInfo"] .NewRow () ; 
// 填 人 内 容 
newdr["username"] =usernamel; 
newdr["pwd"] —pwdl; 
// 添 加 到 Dataset 
ds.Tables ["userInfo"].Rows.Add (newdr) ; 
// 更 新 数据 库 , 也 就 是 插入 一 条 记录 
int i =da.Update (ds, "userInfo"); 
if (i >0) 
{ ”Labell.Text =" 添 加 成 功 !"; 
} 
else 


{ Labell.Text =" 添 加 失败 !"; 
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} 
con.Close(); 


} 


最 终 运 行 结果 与 6.3.3 节 的 相似 ,在 输入 用 户 数 据 后 , 单 击 “ 添 加 ”按钮 ,可 以 看 到 成 功 
地 插入 一 条 记录 。 


6.4.6 更 新 记录 


DataSet 对 象 的 更 新 记录 操作 ,因为 拥有 更 新 条 件 , 所 以 需要 使 用 循环 查找 需要 更 新 的 
记录 ,然后 才能 更 新 记录 数据 ,代码 如 下 : 


foreach (DataRow dar in ds .Tables["userInfo"] .Rows) 

t 
if (dar["username"] --username.Text && dar["pwd"] ==pwd.Text) 
t dar["pwd"] —-repwd.Text; 
) 

) 


上 述 foreach 循环 走访 DataTable 对 象 的 所 有 DataRow 对 象 , 使 用 If 条件 检 查 是 否 为 
指定 的 用 户 账号 ,如 果 是 ,更 新 DataRow 对 象 的 密码 字段 。 
user update. apx 页 面 的 代码 如 下 : 


<div> 

用 户 名 : <asp:TextBox ID- username" runat= "server">< /asp:TextBox><br /> 

密 &nbsp; li]: <asp:TextBox ID= "pwd" runat="server" TextMode- "Password"> 

< /asp:TextBox> <br /> 

修改 密码 : <asp:TextBox ID= "repwd" runat- "server" TextMode= "Password"> 

< /asp:TextBox» «br /> 

«asp:Button ID- "Buttonl" runat="server" Text- "确认 " OnClick- "Buttonl Click" /> 
<asp:Label ID- "Labell" runat- "server">< /asp:Label» 

</div> 


user update. aspx. cs 页 面 的 代码 如 下 : 


protected void Buttonl Click (object sender, EventArgs e) 
{ // 建 立 跟 数 据 库 的 连接 
string strConn = @"Data Source =. V SQLEXPRESS; Initial Catalog = students; Integrated 
Security- True"; 
SqlConnection con =new SglConnection (strConn); 
con.Open() ; 
// 建 立 Command 对 象 实现 update 
string strSql = "select * from userInfo"; 
SqlDataAdapter da =new SqlDataAdapter (strSql, con); 
SqiCommandBuilder cb =new SqlCommandBuilder (da) ; 
DataSet ds —new DataSet () ; 
da.Fill(ds, "userInfo"); 
//DataRow dar; 
«7 x 


foreach (DataRow dar in ds.Tables ["userInfo"].Rows) 

{ if (dar["username"] —--username.Text && dar["pwd"] ==pwd.Text) 
t dar["pwd"] —-repwd.Text; 
} 

} 

int i =da.Update (ds, "userInfo"); 

if (i >0) 

{ ”Labell.Text =" 更 新 数据 成 功 !"; 

¥ 

else 

{ ”Labell.Text =" 更 新 数据 失败 !"7 

} 

con.Close(); 

) 


最 终 运 行 的 结果 跟 6. 3. 5 节 的 相似 ,在 输入 更 新 用 户 的 账号 和 密码 后 , 单 击 “ 确 认 ” 按 
钮 ,可 以 看 到 更 新 一 条 记录 。 


6.4.7 删除 记录 
同样 方式 ,可 以 使 用 DataSet 对 象 来 删除 数据 表 中 的 记录 ,语句 如 下 ， 


foreach (DataRow dar in ds.Tables["userInfo"].Rows) 
{ if (dar["username"] ==username .Text) 


( dar.Delete(); // 删 除 此 记录 


) 


上 述 foreach 循环 查看 DataTable 对 象 的 所 有 DataRow 对 象 , 使 用 If 条 件 检查 是 否 是 
指定 的 用 户 账 号 ,如 果 是 ,使 用 Delete 方法 删除 DataRow 对 象 。 
user. delete. apx 页 面 的 代码 如 下 : 


<div> 
用 户 名 : <asp:TextBox ID= "username" runat- "server"»« /asp:TextBox»«br /> 
«asp:Button ID-"Buttonl" runat="server" OnClick-"Buttonl Click" Text-" 删除 数据 " 
OnClientClick- "return confirm(' 你 确实 要 删除 吗 ?');" /> 
<asp:Label ID- "Labell" runat- "server">< /asp:Label> 
</div> 


user delete. aspx. cs 页 面 的 代码 如 下 : 


protected void Buttonl Click (object sender, EventArgs e) 

{  // 建 立 跟 数据 库 的 连接 
string strConn =@"Data Source- .\SQLEXPRESS; Initial Catalog- students; 
Integrated Security- True"; 
SqlConnection con =new SqlConnection (strConn); 
con.Open () 7 
// 建 立 Command 对 象 实现 update 

。68 。 


) 


string strSql -"select * from userInfo"; 
SglDataAdapter da =new SqlDataAdapter (strSql, con); 
SqlCommandBuilder cb - new SqlCommandBuilder (da) ; 
DataSet ds =new DataSet (); 

da.Fill(ds, "userInfo"); 

//DataRow dar; 

foreach (DataRow dar in ds.Tables["userInfo"].Rows) 
{ if (dar["username"] ==username.Text) 


{ dar.Delete(); // 删 除 此 记录 


H 

int i =da.Update (ds, "userInfo"); 

if (i»0) 

{ Labell.Text =" 更 新 数据 成 功 !"; 
} 

else 

{ Labell.Text = "更 新 数据 失败 !"; 
} 

con.Close(); 


最 终 执行 结果 与 6. 3. 6 节 的 相似 ,在 输入 删除 的 用 户 账号 后 , 单 击 * 删 除数 据 ? 按 钮 就 可 
以 看 到 删除 一 条 记录 。 


6.5 


从 数据 表 中 获取 单一 字段 值 


ADO. NET 的 Command 对 象 提 供 多 个 Execute 方法 , 前 面部 分 只 使 用 了 
ExecuteNonQuery() 方 法 ,本 节 介 绍 ExecuteScalar() 方 法 的 使 用 ,此 方法 可 以 获取 数据 表 


指定 记录 的 单一 字段 值 ,比方 说 得 到 数据 库 中 Sum Count 函数 的 返回 值 。 


ExecuteScalar() 方 法 执行 SQL 命令 ,如 果 返 回 值 不 止 一 个 ,例如 多 条 记录 ,获取 的 是 第 
1 条 记录 的 第 1 个 字段 。 


本 案例 是 到 数据 库 中 检索 一 共有 多 少 条 记录 ,具体 代码 如 下 。 


scalarTest. aspx 页 面 的 代码 如 下 : 


«div» 


userInfo 表 中 共有 <asp:Label ID- "Labell" runat="server" Text- "?'» < /asp: 


Label> 条 记录 <asp:Button 


ID="Buttonl" runat="server" OnClick="Buttonl Click" Text=" 显 示 " /> 


</div> 


scalarTest. aspx. cs 页 面 的 代码 如 下 : 


protected void Buttonl Click (object sender, EventArgs e) 


t 


// 建 立 跟 数据 库 的 连接 


string strConn =@"Data Source= .\SQLEXPRESS; Initial Catalog- students; 
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Integrated Security- True"; 

SqlConnection con =new SqlConnection (strConn); 
con.Open() ; 

// 建 立 Command 对象 

string strSql =@"select count(* ) from [userInfo]"; 
SqlCommand com - new SqlCommand(strSql, con); 
Labell.Text = com.ExecuteScalar ().ToString(); 
con.Close(); 


) 
最 终 的 运行 结果 如 图 6. 5 所 示 。 
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6.6 DataReader 对 象 以 表格 显示 数据 表 


通常 使 用 表格 在 ASP. NET 程序 中 显示 数据 表 内 容 , 以 一 行 代 表 一 条 记录 ,每 一 列 为 
一 个 字段 。 本 节 中 使 用 表格 显示 数据 表 中 的 信息 。 第 7 章 中 是 以 数据 源 和 Web 控件 显示 
数据 表 中 的 记录 数据 。 

显示 数据 表 中 的 所 有 数据 的 具体 步骤 如 下 。 

(1) 建立 Connection 对 象 。 

如 同 数据 库 操作 ,用 户 需 要 使 用 Connection 对 象 来 建立 跟 数 据 库 的 连接 ,代码 如 下 ; 


string strConn =@"Data Source- .\SQLEXPRESS; Initial Catalog- students; Integrated Security- True"; 
SqlConnection con =new SqlConnection (strConn); 


上 述 代码 建立 了 跟 数 据 库 的 连接 对 象 con。 

(2) 建立 Command 对 象 。 

在 建立 好 Connection 对 象 后 ,就 可 以 使 用 SQL 命令 和 Connection 对 象 为 参数 来 建立 
Command 对 象 ,代码 如 下 : 


string strSql =@"select * from [userInfo]"; 
SqlCommand com - new SqlCommand(strSql, con); 


1. 执行 SQL 命令 查询 数据 表 
接着 使 用 ExecuteReader() 方 法 来 执行 SQL 命令 ,可 以 获取 DataReader 对 象 , 代 码 
如 下 : 
UR 


public SqlDataReader dr; 
dr —com.ExecuteReader () ; 


2. 取出 查询 结果 的 数据 表 记 录 数 据 
DataReader 对 象 是 一 种 流 数据 ,可 以 使 用 while 循环 读 取 数 据 表 的 每 一 条 记录 ,代码 
AT: 


<% 
while (dr.Read()) 
t 
$» 
«tr»«td»«$-dr["username"] .ToString () >< /td» « td» « $- dr ["pud"] .'ToString () $> 
« /td» « /tr» 
<%} 
dr.Close(); 
5> 


上 述 while 循环 使 用 Read() 方 法 读 取 下 一 条 记录 。 也 就 是 将 记录 移动 到 下 一 条 ,如 果 
有 下 一 条 记录 ,返回 True, 和 否则 返回 False。 要 读 取 DataReader 对 象 就 必须 用 Read ) 方 法 
先 看 看 有 没有 记录 。 

因为 本 例 中 在 . aspx 页 面 中 写 人 了 代码 ,在 . aspx 页 面 中 写 代码 必须 用 二 % 96 >R dh 
起 来 。 

dr["username" | 是 读 取 数据 表 中 的 字段 。 

3. 关闭 DataReader 和 数据 库 连接 

最 后 是 关闭 DataReader 对 象 和 数据 库 连接 对 象 。 


dr.Close(); 


con.Close(); 
show. aspx 页 面 的 代码 如 下 : 


«div» 
«b» DataReader 演示 < /b> 
«table border- "1"> 
«tr bgcolor= "4 aaaadd"» « td» JI] P 4 < /td» < td» $ fi « /td» « /tr> 
<% while (dr.Read()) 
t 
$> 
<tr><td < %=dr ["usemame"] .ToString ()%></td><ta><%=dr["pwd"] .TbString ()%> 
« /td» « /tr» 
<5} 
dr.Close(); 
$» 
« /table» 
</div> 


show. aspx. cs 页 面 的 代码 如 下 : 
EE. 


public SqlDataReader dr; 
protected void Page Load(object sender, EventArgs e) 
{ // 建 立 跟 数据 库 的 连接 
string strConn = @" Data Source =. V SQLEXPRESS; Initial Catalog = students; Integrated 
Security- True"; 
SqlConnection con - new SqlConnection (strConn); 
con.Open() ; 
string strSql -G"select * from [userInfo]"; 
SqlCommand com - new SqlCommand (strSql, con) ; 
dr —com.ExecuteReader (CommandBehavior.CloseConnection) ; // 自 动 地 关闭 相应 的 连接 对 象 
} 


最 终 的 运行 结果 如 图 6.6 所 示 。 


ESTRER HAE EE 5x 
XD bo) SEV BEW IAW #M?| P 
Om- O AA Gle ea” 
HAED) [Æ http://localhost: 1044/test/sho z] E] 89 | E > 


DataReader 演 示 


Izhangsan 
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代码 分 析 : 


dr= com.ExecuteReader (CommandBehavior.CloseConnection); 


因为 如 果 是 在 show. aspx. cs 页 面 中 用 con. CloseO fij ifi ,把 连接 关闭 ,show. aspx 页 面 
就 获取 不 到 dr 对 象 ,就 无 法 正常 显示 。 因 为 DataReader 对 象 是 跟 数据 库 建 立 的 连接 ,在 执 
行 时 加 入 CommandBehavior. CloseConnection 这 个 参数 就 会 用 完 dr 对 象 后 自动 地 关闭 连 
接 对 象 , 就 不 用 显 式 地 关闭 连接 对 象 。 


6.7 DataSet 对 象 以 表格 显示 数据 表 


DataSet 对 象 可 以 建立 存储 在 内 存 的 数据 库 , 它 是 将 数据 表 的 记录 和 字段 数据 转换 为 对 象 
结构 。DataSet 对 象 拥有 多 个 DataTable 对 象 ,每 一 个 DataTable 对 象 是 一 个 数据 表 ,DataTable 
是 一 个 表格 ,可 以 使 用 行 或 列 来 存 取 数 据 , 即 DataRowCollection 和 DataColumnCollection 集合 
对 象 , 在 集合 对 象 的 每 一 个 DataRow 对 象 是 一 行 , 即 一 条 记录 ,每 一 个 DataColumn 对 象 是 
一 列 。 

对 于 DataTable 对 象 ,可 以 建立 DataView 对 象 ,相当 于 关系 型 数据 库 的 视图 (views)， 
是 一 种 定义 在 数据 表 中 的 虚拟 数据 表 , 简 单 地 说 ,就 是 预先 定义 的 数据 表 查 询 结 果 。 

TE 


因为 数据 表 通 常 是 以 记录 为 单位 ,所 以 DataColumn 对 象 比较 少 用 ,通常 只 会 使 用 
DataSet, Data Table, DataRowCollection 和 DataRow 对 象 来 处 理 数据 表 。 

当 使 用 DataAdapter 对 象 将 数据 表 的 记录 数据 填 人 DataSet 对 象 后 ,就 可 以 使 用 
foreach 循环 从 DataRowCollection 集合 对 象 取 出 每 一 个 DataRow 对 象 , 代 码 如 下 : 


foreach (DataRow dar in ds.Tables ["userInfo"].Rows) 

{ Response.Write ("« tr» "); 
Response.Write ("< td>" * dar ["username"] 4 "« /td»"); 
Response.Write ("< td>" - dar["pwd"] +"< /td»"); 
Response.Write ("< /tr>"); 

} 


show. aspx 页 面 的 代码 如 下 : 


< $8&Page Language= "C£ " AutoEventWireup- "True" CodeFile- "showl.aspx.cs" 
Inherits- "showl" $» 
< $8Import Namespace- "System.Data" $> 
< $eImport Namespace- "System.Data .SqlClient" $» 
< !DOCTYPE html PUBLIC "- //W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/ 
DTD/xhtmll- transitional.dtd"> 
«html xmlns= "http: //www.w3.0rg/1999/xhtml" > 
X head runat="server"> 
«title» DataSet 显示 数据 表 中 的 数据 < /title> 
< /head» 
«body» 
< form id- "forml" runat="server"> 
«div» 
«b» DataSet 演示 < /b> 
«table border="1"> 
«tr bgcolor- "4 aaaadd"» « td» JI] P! 4 < /td» < td» ti fid « /td» < /tr> 
<%// 建 立 跟 数据 库 的 连接 
string strConn = @"Data Source=.\ SQLEXPRESS; Initial Catalog- students; Integrated 
Security- True"; 
SqlConnection con =new SqlConnection (strConn); 
con.Open() 
string strSql =@"select * from [userInfo]"; 
SglDataAdapter da =new SqlDataAdapter (strSql, con); 
DataSet ds -new DataSet (); 
da.Fill (ds, "userInfo"); 
foreach (DataRow dar in ds.Tables ["userInfo"].Rows) 
t 
Response.Write ("<tr>"); 
Response.Write ("< td» " - dar["username"] +"< /td» "); 
Response.Write ("« td» " - dar["pwd"] 4 "« /td» "); 
Response.Write ("< /tr» "); 


a qe 


con.Close():; 
$» 
« /table» 
</div> 
< /form» 
< /body> 
< /html> 


最 终 运行 的 结果 如 图 6.7 所 示 。 


6.8 小 结 


本 章 主要 介绍 了 ADO. NET 中 包含 的 主要 对 象 的 使 用 方式 ,并 且 介绍 了 ADO. NET 
的 两 种 不 同 的 处 理 数据 库 的 方式 : 一 种 是 有 连接 的 处 理 方式 ,主要 使 用 的 对 象 有 
Connection XJ £ , Command 对 象 和 DataReader 对 象 等 ; 另 一 种 方式 是 无 连接 方式 ,使 用 的 
对 象 主要 是 DataSet 和 DataAdapter, CommandBuilder 的 使 用 。 本 章 主 要 是 介绍 如 何 使 用 
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ADO.NET 对 数据 库 的 操纵 。 


课 后 思考 问题 


1. 使 用 Command 对 象 实现 对 数据 库 的 增加 、 删 除 .修改 功能 。 
2. 使 用 DataReader 对 象 实现 对 数据 库 的 查询 功能 。 
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$753 数据 控件 


本 章 要 点 

。 了 解数 据 源 控件 的 使 用 。 

。 掌握 数据 绑 定 知识 。 

。 掌握 GridView 控件 的 使 用 。 
。 掌握 DataList 控件 的 使 用 。 

* 掌握 Repeater 控件 的 使 用 。 


在 了 解 了 ADO. NET 基础 后 ,就 可 以 使 用 ADO. NET 提供 的 对 象 进行 数据 库 开 发 和 
操作 。ASP. NET 还 提供 了 一 些 Web 窗 体 的 数据 控件 ,开发 人 员 能 够 智能 地 配置 与 数据 库 
的 连接 ,而 不 需要 手动 编写 数据 库 连 接 。ASP. NET 不 仅 提 供 了 数据 源 控件 ,还 提供 了 能 够 
显示 数据 的 控件 ,简化 了 数据 显示 的 开发 ,开发 人 员 只 需要 简单 地 修改 模板 就 能 够 实现 数据 
显示 和 分 页 。 


7.1 数据 源 控件 


数据 源 控件 很 像 ADO. NET 中 的 Connection 对 象 ,数据 源 控件 用 来 配置 数据 源 , 当 数 
据 控 件 绑 定 数据 源 控 件 时 ,就 能 够 通过 数据 库 源 控件 来 获取 数据 源 中 的 数据 并 显示 ,而 无 须 
通过 程序 实现 数据 源 代 码 的 编写 。 

SqlDataSource 控件 代表 一 个 通过 ADO. NET 连接 到 SQL 数据 库 提供 者 的 数据 源 控 
件 。 并 且 SqlDataSource 能 够 与 任何 一 种 ADO. NET 支持 的 数据 库 进 行 交 互 , 这 些 数据 库 
包括 SQL Server, Access, Oledb, ODBC 以 及 Oracle, 

SqlDataSource 控件 能 够 支持 数据 的 检索 .插入 .更 新 .删除 和 排序 等 ,以 至 于 数据 绑 定 
控件 可 以 在 这 些 能 力 被 允许 的 条 件 下 自动 地 完成 该 功能 ,而 不 需要 手动 的 代码 实现 。 并 且 
SqlDataSource 控件 所 属 的 页 面 被 打开 时 ,SqlDataSource 控件 能 够 自动 地 打开 数据 库 ,执行 
SQL 语句 或 存储 过 程 ,返回 选 定 的 数据 ,然后 关闭 连接 。SqlDataSource 控件 强大 的 功能 极 
大 地 简化 了 开发 人 员 的 开发 ,缩减 了 开发 中 的 代码 。 但 是 SqlDataSource 控件 也 有 一 些 缺 
点 ,就 是 在 性 能 上 不 太 适 应 大 型 的 开发 .而 对 于 中 小 型 的 开发 ,SqlDataSource 控件 已 经 足 
ET. 

ASP. NET 提供 的 SqlDataSource 控件 能 够 方便 地 添加 到 页 面 , 当 SqlDataSource 控件 
被 添加 到 ASP. NET 页 面 中 时 ,会 生成 ASP. NET 标签 ,示例 代码 如 下 : 


<asp:SqlDataSource ID- "SqlDataSourcel" runat- "server">< /asp:SqlDataSource> 


切换 到 视图 模式 下 , 单 击 SqlDataSource 控件 会 显 式 “ 配 置 数据 源 …… ”, 单 击 “ 配 置 数 据 
Wee ”连接 时 ,系统 能 够 智能 地 提供 SqlDataSource 控件 配置 向 导 ,如 图 7.1 所 示 。 
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图 配置 控件 


新 建 数据 源 后 ,开发 人 员 可 以 选择 是 否 保存 在 web. config 数据 源 中 以 便 应 用 程序 进行 全 
局 配置 ,通常 情况 下 选择 保存 。 由 于 现在 没有 连接 , 单 击 “ 新 建 连接 ”按钮 选择 或 创建 一 个 数据 


| 用 于 SQL Server 的 .NET Framework 


d 


图 选择 数据 源 ” 对 话 框 


选择 数据 源 后 , 单 击 “ 继 续 ” 按 钮 ,来 配置 跟 
数据 库 连 接 的 信息 ,如 图 7. 3 所 示 。 当 配置 好 连 
接 后 ,可 以 单 击 * 测 试 连接 ”按钮 来 测试 是 否 连 接 
成 功 。 

连接 成 功 后 , 单 击 * 确 定 ” 按 钮 ,系统 会 自动 
添加 连接 ,如 图 7.4 所 示 。 

单 击 “ 下 一 步 ” 按 钮 ,会 出 现 是 否 将 连接 保存 
到 配置 文件 中 , 如 果 选 是 的 话 , 就 会 在 web. 
config 配置 文件 中 建立 该 连接 的 连接 字符 串 , 当 
需要 对 用 户 控件 进行 维护 时 ,可 以 直接 修改 web. 
config ,而 不 需要 修改 每 个 页 面 的 数据 源 控件 ,这 
样 就 方便 了 开发 和 维护 ,如 图 7.5 所 示 。 

在 web. config 配置 文件 中 添加 的 代码 如 下 : 


<connectionstrings> 
< add name-"strConn" connectionString- "Data 
Source = examserver03 \ SQLEXPRESS; Initial 
i 5 


E 成 功 添 加 连接 


图 在 配置 文件 中 保存 连接 信息 


Catalog- Student; Integrated Security- True" 
providerName- "System.Data.SqlClient" /> 
< /connectionstrings» 


数据 源 控件 可 以 指定 开发 人 员 所 需要 使 用 的 select 语句 或 存储 过 程 ,开发 人 员 能 够 在 
配置 select 语句 窗口 中 进行 select 语句 的 配置 和 生成 ,如 果 开 发 人 员 希 望 手动 编写 select 
语句 或 其 他 语句 ,可 以 单 击 “ 指 定 自 定义 SQL 语句 或 存储 过 程 ” 按 钮 进行 自 定义 配置 ,select 
语句 的 配置 和 生成 如 图 7.6 所 示 。 

单 击 “ 下 一 步 ” 按 钮 ,会 出 现 测 试 查询 页 面 . 单 击 “ 完 成 ”按钮 完成 对 数据 源 的 配置 。 

对 于 开发 人 员 ,只 需要 勾 选 相应 的 字段 ,选择 Where 条 件 和 Order By 语句 就 可 以 配置 
一 个 Select 语句 。 但 是 ,通过 选择 只 能 够 查询 一 个 表 , 并 实现 简单 的 查询 语 。 如 果 要 实现 复 
杂 的 SQL 查询 语句 ,可 以 单 击 * 指 定 自 定义 SQL 语句 或 存储 过 程 ”进行 自 定义 SQL 语句 或 
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图 配置 使 用 语句 


存储 过 程 的 配置 ,开发 人 员 选 择 了 一 个 getdetail 的 存储 过 程 作为 数据 源 。 
单 击 “下 一 步 ?按钮 ,就 需要 对 相应 的 字段 进行 配置 ,这 些 字段 就 像 ADO. NET 中 的 参 
数 化 查询 一 样 。 在 数据 源 控 件 中 ,也 是 通过 @ 来 表示 参数 化 变量 , 当 需 要 配置 相应 的 字段 ， 
例如 配置 WHERE 语句 等 就 需要 对 参数 进行 配置 。 
添加 WHERE 子 句 时 ,SQL 语句 中 的 值 可 以 选择 默认 值 .控件 .Cookie 或 者 是 Session 
等 。 当 配置 完成 后 ,就 可 以 测试 查询 ,如 果 测 试 后 显示 的 结果 和 预期 一 样 , 则 可 以 单 击 完成 。 
完成 后 ,SqlDataSource 控件 标签 代码 如 下 : 
< asp: SqlDataSource ID =" SqlDataSourcel" runat =" server" ConnectionString =" <$% $ 
ConnectionStrings:strConn $5" 
SelectCommand- "select * from [T students]"» « /asp:SqlDataSource» 
注意 : 上 例 配 置 数 据 库 时 使 用 的 是 Windows 身份 验证 ,也 可 以 选择 SQL Server 身份 
验证 ,不 过 SQL Server 身份 验证 要 求 填 写 用 户 名 和 密码 ,两 者 产生 的 连接 字符 串 不 同 。 使 
用 任何 一 种 都 可 以 。 


7.2 数据 绑 定 


数据 绑 定 (Data Binding) 的 概念 最 早出 现在 Internet Explorer 4. 0, 主 要 是 使 用 客户 端 
的 Dynamic HTML(DHTML) 技 术 , ASP. NET 也 支持 数据 绑 定 ,能 够 将 外 部 数据 整合 到 
ASP. NET 服务 器 端 控件 。 


7.2.1 数据 绑 定 基础 


ASP. NET 数据 绑 定 是 指 服务 器 端的 数据 绑 定 ,可 以 将 外 部 数据 整合 到 服务 器 端 控件 。 
1. 服务 器 端 数据 绑 定 
服务 器 端 数据 绑 定 具有 高 扩充 性 .可 重复 性 和 容易 维护 的 特点 ,ASP. NET 的 数据 绑 定 
就 是 . NET Framework 的 数据 绑 定 技术 ,这 是 一 种 不 同 于 Microsoft 公司 之 前 产品 的 数据 
。78。 


绑 定 技术 。 

.NET Framework 的 数据 绑 定 技术 是 指 将 控件 属性 连接 到 任何 可 用 数据 (Data) ,在 此 
的 数据 可 以 是 单纯 数据 对象 属 性 .控件 名 称 的 集合 对 象 等 ,. NET Framework 可 以 将 这 些 
数据 视 为 类 的 属性 来 存 取 。 

2. ASP. NET 控件 与 数据 绑 定 

ASP. NET 控件 支持 数据 绑 定 ,可 以 将 不 同 数 据 源 的 集合 对 象 、. 数 组 DataReader 或 
DataView 对 象 整合 到 ASP. NET 控件 。 

不 过 ,不 是 每 个 ASP.NET 控件 都 支持 数据 绑 定 ,只 有 具有 DataSource 属性 的 控件 才 
支持 数据 绑 定 。 例 如 ,ListBox、DropDownList CheckBoxList, RadioButtonList, Repeater, 
DataList GridView 等 ,才能 使 用 。 

简单 地 说 ,List 控件 的 数据 绑 定 其 连接 数据 可 以 视 为 是 一 维 数组 ,也 就 是 连接 到 List 
控件 的 选项 ,Repeater、DataList、GridView 等 控件 是 二 维 数组 的 表格 ,可 以 显示 整个 数据 表 
的 记录 数据 。 

在 ASP. NET 控件 中 使 用 数据 绑 定 技术 的 步骤 如 下 。 

(1) 定义 数据 源 和 获取 数据 源 的 数据 对 象 。 

(2) 指定 控件 的 DataSource 属性 为 数据 源 的 对 象 ,对 数据 库 来 说 就 是 DataReader 或 
DataView 对 象 。 

(3) 执行 控件 的 DataBind() 方 法 建立 数据 绑 定 。 

在 执行 上 述 步骤 后 ,数据 源 的 数据 就 会 自动 添 入 控件 中 ,并 且 以 控件 默认 方式 显示 数 
据 , 当 然 也 可 以 设 定 控件 属性 来 变更 显示 方式 和 外 观 。 


7.2.2 ListBox 控件 的 数据 绑 定 
在 页 面 上 拖 放 一 个 ListBox 控件 ,不 设置 它 的 选项 内 容 , 代 码 如 下 : 


«asp:ListBox ID= "ListBoxl" runat- "server"> < /asp:ListBox> 
<asp:Button ID= "Buttonl" runat- "server" onclick- "Buttonl Click" Text- "Button" /> 
<asp:Label ID- "Labell" runat="server" Text- "Label">< /asp:Label» 


在 页 面 上 加 入 了 一 个 Button 控件 和 Label 控件 , 当 单 击 Button 时 在 Label 控件 中 显示 
ListBox 控件 中 选中 的 内 容 。ListBox 控件 中 的 选项 是 通过 数据 绑 定 的 方式 添加 的 ,代码 
如 下 : 


protected void Page Load (object sender, EventArgs e) 
( if (!IsPostBack) // 第 一 次 加 载 页 面 时 进行 下 面 处 理 
{ string[] groups ={".NET 框 架 ","JSP",， "PHP", "JAVA", "XML", "HTML" ); 
ListBoxl.DataSource —- groups; 
ListBoxl.DataBind(); 
} 
} 
protected void Buttonl Click (object sender, EventArgs e) 
{ Labell.Text —ListBoxl.SelectedItem.Text; 
} 


EE 


最 终 的 运行 结果 如 图 7.7 所 示 。 
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E 数据 绑 定 运行 结果 


7.3 数据 列表 控件 


数据 列表 控件 GridView 是 ASP. NET 中 功能 非常 丰富 的 控件 之 一 , 它 可 以 以 表格 的 
形式 显示 数据 库 的 内 容 并 通过 数据 源 控 件 自动 绑 定 和 显示 数据 。 开 发 人 员 能 够 通过 配置 数 
据 源 控件 对 GridView 中 的 数据 进行 选择 .排序 .分 页 .编辑 和 删除 功能 进行 配置 。 
GridView 控件 还 能 够 指定 自 定 义 样式 ,在 没有 任何 数据 时 可 以 自 定 义 无 数 据 时 的 UI 
样式 。 


7.3.1 GridView 控件 的 常用 事件 


GridView 支持 多 个 事件 ,通常 对 GridView 控件 进行 排序 .选择 等 操作 时 ,同样 会 引发 
事件 , 当 创建 当前 行 或 将 当前 行 绑 定 至 数据 时 发 生 的 事件 ,同样 , 单 击 一 个 命令 控件 时 也 会 
引发 事件 。GridView 控件 常用 的 事件 如 下 。 

(D RowCommand。 在 GridView 控件 中 单 击 某 个 按钮 时 发 生 。 此 事件 通常 用 于 在 该 
控件 中 单 击 某 个 按钮 时 执行 某 项 任务 。 

(2) PageIndexChanging。 在 单 击 页 导航 按钮 时 发 生 , 但 在 GridView 控件 执行 分 页 操 
作 之 前 。 此 事件 通常 用 于 取消 分 页 操作 。 

(3) PageIndexChanged。 在 单 击 页 导航 按钮 时 发 生 , 但 在 GridView 控件 执行 分 页 操作 
之 后 。 此 事件 通常 用 于 在 用 户 定位 到 该 控件 中 不 同 的 页 之 后 需要 执行 某 项 任务 时 。 

(4) SelectedIndexChanging。 在 单 击 GridView 控件 内 某 一 行 的 Select 按钮 (其 
CommandName 属性 设置 为 Select 的 按钮 ) 时 发 生 , 但 在 GridView 控件 执行 选择 操作 之 
前 。 此 事件 通常 用 于 取消 选择 操作 。 

(5) SelectedIndexChanged。 在 单 击 GridView 控件 内 某 一 行 的 Select 按钮 时 发 生 , 但 
在 GridView 控件 执行 选择 操作 之 后 。 此 事件 通常 用 于 在 选择 了 该 控件 中 的 某 行 后 执行 某 
项 任务 。 

(6) Sorting。 在 单 击 某 个 用 于 对 列 进行 排序 的 超 链接 时 发 生 , 但 在 GridView 控件 执 
行 排序 操作 之 前 。 此 事件 通常 用 于 取消 排序 操作 或 执行 自 定义 的 排序 例 程 。 

(7) Sorted。 在 单 击 某 个 用 于 对 列 进行 排序 的 超 链接 时 发 生 , 但 在 GridView 控件 执行 
排序 操作 之 后 。 此 事件 通常 用 于 在 用 户 单 击 对 列 进行 排序 的 超 链接 之 后 执行 某 项 任务 。 
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(8) RowDataBound, Æ GridView 控件 中 的 某 个 行 被 绑 定 到 一 个 数据 记录 时 发 生 。 此 
事件 通常 用 于 在 某 个 行 被 绑 定 到 数据 时 修改 该 行 的 内 容 。 

(9) RowCreated。 在 GridView 控件 中 创建 新 行 时 发 生 。 此 事件 通常 用 于 在 创建 某 个 
行 时 修改 该 行 的 布局 或 外 观 。 

(10) RowDeleting。 在 单 击 GridView 控件 内 某 一 行 的 Delete 按钮 (其 CommandName 
属性 设置 为 Delete 的 按钮 ) 时 发 生 , 但 在 GridView 控件 从 数据 源 删 除 记录 之 前 。 此 事件 通 
常用 于 取消 删除 操作 。 

(11) RowDeleted。 在 单 击 GridView 控件 内 某 一 行 的 Delete 按钮 时 发 生 , 但 在 
GridView 控件 从 数据 源 删除 记录 之 后 。 此 事件 通常 用 于 检查 删除 操作 的 结果 。 

(12) RowEditing。 在 单 击 GridView 控件 内 某 一 行 的 Edit 按钮 (其 CommandName 属 
性 设置 为 Edit 的 按钮 ) 时 发 生 ,但 在 GridView 控件 进入 编辑 模式 之 前 。 此 事件 通常 用 于 取 
消 编辑 操作 。 

(13) RowCancelingEdit。 在 单 击 GridView 控件 内 某 一 行 的 Cancel 按钮 (其 CommandName 
属性 设置 为 Cancel 的 按钮 ) 时 发 生 , 但 在 GridView 控件 退出 编辑 模式 之 前 。 此 事件 通常 用 
于 停止 取消 操作 。 

(14) RowUpdating。 在 单 击 GridView 控件 内 某 一 行 的 Update 按钮 (其 CommandName 
属性 设置 为 Update 的 按钮 ) 时 发 生 , 但 在 GridView 控件 更 新 记录 之 前 。 此 事件 通常 用 于 
取消 更 新 操作 。 

(15) RowUpdated。 在 单 击 GridView 控件 内 某 一 行 的 Update 按钮 时 发 生 , 但 在 
GridView 控件 更 新 记录 之 后 。 此 事件 通常 用 来 检查 更 新 操作 的 结果 。 

(16) DataBound。 此 事件 继承 自 BaseDataBoundControl 控件 ,在 GridView 控件 完成 
到 数据 源 的 绑 定 后 发 生 。 


7.3.2 使 用 GridView 控件 绑 定数 据 源 


下 面 示例 先 利 用 SqlDataSource 控件 配置 数据 源 , 连 接 数据 后 ,使 用 GridView 控件 绑 


Columno Columnl Column2 
程序 实现 主要 步骤 如 下 。 abc abc abc 
COD 新 建 一 个 网 站 ,默认 主页 为 Default. aspx。 abe a ga 
添加 1 个 GridView 控件 和 1 个 SqlDataSource 控件 ， abc abc abc 
— abc abc abc 
如 图 7. 8 所 示 。 BalDataSource - SqlDataSourcel 
(2) 配置 SqlDataSource 控件 : 所 有 的 配置 请 参 
照 7.1.1 节 图 在 页 面 中 添加 控件 和 
EU 控件 后 的 效果 
(3) 将 获取 的 数据 源 绑 定 到 Grid View 控件 上 ,如 
图 7.9 所 示 。 


(4) 单 击 GridView 控件 右上 方 的 固 按钮 ,在 弹出 的 快捷 菜单 中 选择 “编辑 列 ? 选 项 ,如 
图 7. 10 所 示 。 

(5) 将 每 个 BoundField 控件 绑 定 字段 的 HeaderText 属性 设置 为 该 列 头 标题 名 ,把 
DataField 属性 设置 为 字段 名 .。“ 字 段 ? 对 话 框 如 图 T. 11 所 示 。 
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执行 程序 ,示例 运行 结果 如 图 7. 12 所 示 。 
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xx0006 高 兴 19 
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7.3.3 设置 GridView 控件 的 外 观 
默认 状态 下 ,GridView 控件 的 外 观 是 简单 的 表格 。 为 了 美化 网 页 的 界面 ,丰富 页 面 的 


。82 。 


显示 效果 ,开发 人 员 可 以 通过 多 种 方式 来 美化 Grid View 控件 的 外 观 。 


GridView 控件 常用 外 观 属性 如 表 7. 1 所 示 。 
表 7.1 GridView 控件 常用 外 观 属 性 及 说 明 

属 性 说 明 
BackColor 用 来 设置 GridView 控件 的 背景 颜色 
BackImageUrl 用 来 设置 GridView 控件 的 背景 中 的 图 片 的 URL 
BorderColor 用 来 设置 GridView 控件 的 边框 颜色 
BorderStyle 用 来 设置 GridView 控件 的 边框 样式 
BorderWidth 用 来 设置 GridView 控件 的 边框 的 宽度 
Caption 用 来 设置 GridView 控件 的 标题 文字 


CaptionAlign 


用 来 设置 GridView 控件 的 标题 文字 的 布局 位 置 


CellPadding 


用 来 设置 Grid View 控件 的 单元 格 内 容 和 单元 格 之 间 的 空间 量 


CellSpacing 


用 来 设置 GridView 控件 的 单元 格 的 空间 量 


CssClass 用 来 设置 GridView 控件 在 客户 端 呈 现 的 CSS 样式 
Font 用 来 设置 GridView 控件 的 关联 的 字体 属性 
ForeColor 用 来 设置 GridView 控件 的 前 景色 

GridLines 用 来 设置 GridView 控件 的 网 格 线 样式 

Height 用 来 设置 GridView 控件 的 高 度 


HorizontalAlign 


用 来 设置 Grid View 控件 在 页 面 上 的 水 平 对 齐 方式 


ShowFooter 用 来 设置 GridView 控件 是 否 显示 页 脚 
ShowHeader 用 来 设置 GridView 控件 是 否 显示 页 眉 
Width 用 来 设置 GridView 控件 的 宽度 


还 可 以 通过 自动 套用 格式 来 改变 GridView 控件 的 外 观 。 单 击 “ 自 动 套 用 格式 ”, 弹 出 “ 自 
动 套 用 格式 ”对 话 框 ,如 图 7. 13 所 示 。 在 对 话 框 左 侧 可 以 看 到 GridView 给 出 的 几 种 样式 。 


T 
数据 绑 定 数据 绑 定 数据 绑 定 数据 绑 定 
数据 绑 定 RERE 数据 绑 定 BEHE 
数据 绑 定 数据 绑 定 KERE KERE 
RERE KERE 数据 绑 定 数据 绑 定 
RERE RERE KERE 数据 绑 定 


图 “自动 套用 格式 ”对 话 框 


7.3.4 制定 GridView 控件 的 列 


GridView 控件 中 的 每 一 列 由 一 个 DataContolField 对 象 表示 。 默 认 情 况 下 ,AutoGenerate- 
Columns 属性 被 设置 为 True ,为 数据 源 中 的 每 一 个 字段 创建 一 个 AutoGenerateColumns 对 
象 。 将 AutoGenerateColumns 属性 设置 为 False 时 ,可 以 自 定 义 数 据 绑 定 列 。GridView 控 
件 共 包括 7 个 类 型 的 列 ,分 别 为 BoundField( 普 通 数据 绑 定 列 ) .CheckBoxField( 复 选 框 数 据 
绑 定 列 ) CommandField (命令 数据 绑 定 列 ) 和 ImageField (图 片 数 据 绑 定 列 )、 
HyperLinkField( 超 链接 数据 绑 定 列 )、.ButtonField( 按 钮 数据 绑 定 列 )、TemplateField( 模 板 
数据 绑 定 列 ) 。 

1. BoundField 

BoundField 是 默认 的 数据 绑 定 类 型 ,通常 用 于 显示 普通 文本 。 

2. CheckBoxField 

使 用 CheckBoxField 控件 显示 布尔 类 型 的 数据 。 绑 定数 据 为 True 时 , 复 选 框 数据 绑 定 
列 为 选中 状态 ; 绑 定数 据 为 False 时 , 则 显示 未 选中 状态 。 在 正常 情况 下 ,CheckBoxField w 
示 在 表格 中 的 复 选 框 控件 处 于 只 读 状 态 。 只 有 GridView 控件 的 某 一 行进 入 编辑 状态 后 ， 
复 选 框 才 恢复 为 可 修改 状态 。 

3. CommandField 

CommandField 显示 用 来 执行 选择 、 编 辑 或 删除 操作 的 预定 义 命令 按钮 。 这 些 按 钮 可 
以 呈现 为 普通 按钮 、 超 链接 和 图 片 等 外 观 。 

4. ImageField 

ImageField 在 GridView 控件 呈现 的 表格 中 显示 图 片 列 。 通 常 ImageField 绑 定 的 内 容 
是 图 片 的 路 径 。 

5. HyperLinkField 

HyperLinkField 允许 将 所 绑 定 的 数据 以 超 链接 的 形式 显示 出 来 。 开 发 人 员 可 自 定义 
绑 定 超 链接 的 显示 文字 ` 超 链接 的 URL, 以 及 打开 窗口 的 方式 等 。 

6. ButtonField 

ButtonField 也 可 以 为 GridView 控件 创建 命令 按钮 。 开 发 人 员 可 以 通过 按钮 来 操作 其 
所 在 行 的 数据 。 

7. TemplateField 

TemplateField 允许 以 模板 形式 自 定 义 数据 绑 定 列 的 内 容 。 


7.3.5 查看 GridView 控件 中 数据 的 详细 信息 


在 设计 网 页 显示 商品 信息 时 ,通常 需要 考虑 页 面 的 美观 程度 只 把 概要 信息 显示 出 来 。 
需要 查看 商品 的 详细 信息 时 ,通常 会 使 用 一 个 超级 链接 按钮 链接 到 显示 商品 详细 信息 的 页 
面 。 这 样 做 不 但 使 页 面 简化 .美观 ,还 可 以 提高 显示 的 速度 。 下 面 使 用 GridView 控件 来 显 
示 商 品 的 概要 并 使 用 GridView 控件 里 的 HyperLinkField( 超 链接 数据 绑 定 列 ) 链 接 到 商品 
详细 信息 页 做 一 个 实例 。 

程序 实现 的 主要 步骤 如 下 。 

CD 新 建 一 个 网 站 ,默认 主页 为 Default. aspx。 添 加 1 个 SqlDataSource 控件 和 1 个 
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GridView 控件 ,再 建立 一 个 页 面 命名 为 showStudent. aspx. TE showStudent. aspx 页 面 里 
添加 4 个 TextBox 控件 用 来 显示 学 生 的 详细 信息 。 

(2) 配置 SqlDataSource 数据 源 ,在 配置 Select 语句 时 选择 * (所 有 字段 ) 。 

(3) 在 GridView 编辑 列 里 添加 一 个 HyperLinkField( 超 链接 数据 绑 定 列 ) 。 把 超级 链 
接 列 的 DataNavigateUrlFields 属性 设 为 stu. id. DataNavigateUrlFormatString 属性 设 为 
showStudent. aspx?id— (0) , HeaderText 属性 设 为 “查看 详细 信息 ”,NavigateUrl 属性 设 为 
一 /showStudent. aspx, Text 属性 设 为 “详细 信息 ”, 如 图 7. 14 所 示 。 
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图 在 控件 中 编辑 列 的 设置 


(4) 主要 程序 代码 。 

TE showStudent. aspx 页 面 里 接收 超 链接 控件 传送 的 编号 。 通 过 编号 在 数据 表 里 查 询 
出 相同 编号 的 数据 ,把 数据 显示 在 showStudent. aspx 页 面 里 显示 出 来 。 实 现 这 个 功能 需要 
一 个 Bind0O 〇 方法 。BindO 〇 方法 的 代码 如 下 : 


protected void Bind() 


t 


// 建 立 数据 库 连 接 

string strConn =@"Data Source- .\SQLEXPRESS; Initial Catalog- Student; Integrated Security 
=True"; //Windows 身份 验证 

SqlConnection con =new SqlConnection (strConn); 

con.Open (); 

// 创 建 Command 对 象 

string strsql ="select + from T students where stu id='" «Request.QueryString 
i" id"] put i 

SqlCommand com - new SqlCommand (strSql, con); 

// 执 行 SQL 语句 

SqlDataReader dr =com.ExecuteReader () ; 


if (dr.Read()) 
i 
sid.Text -dr["stu id"].ToString(); 
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sName.Text —dr["stu name"].ToString(); 
SAge.Text —dr["stu age"].ToString(); 
SSex.Text —dr["stu sex"].ToString(); 

} 

dr.Close(); 

con.Close(); 


H 

注意 : 此 方法 中 应 用 了 System. Data. SqlClient 命名 空间 中 的 SqlConnection 对 象 , 需 
要 引用 System. Data. SqlClient 命名 空间 ,引用 后 才能 使 用 SqlConnection 对 象 , 以 下 实例 跟 
这 相似 ,将 不 再 提起 引入 命名 空间 的 问题 。 

在 页 面 的 Page Load 事件 里 面 调 用 自 定 义 方法 Bind() ,代码 如 下 : 


protected void Page Load(object sender, EventArgs e) 
( if (!IsPostBack) 
{  Bind(; 


运行 实例 ,结果 如 图 7.15 所 示 。 
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图 查看 详细 信息 首页 


单 击 王 新 后 面 的 “详细 信息 ” 超 链接 ,将 显示 学 生 的 详细 信息 ,如 图 7. 16 所 示 。 
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图 跳 转 到 详细 信息 页 
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7.3.6 使 用 GridView 控件 分 页 显示 数据 


在 网 站 开发 过 程 中 ,经 常 需要 表格 控件 查看 一 些 基 本 信息 ,由 于 信息 过 多 表格 会 变 长 ， 
这 样 网 页 会 不 美观 。 这 种 情况 可 以 使 用 GridView 控件 的 分 页 功能 ,查看 信息 更 为 方便 。 
GridView 控件 的 分 页 功能 也 非常 方便 ,只 需 设 置 如 图 7.17 所 示 的 启用 分 页 即 可 。 

程序 实现 的 主要 步 又 如 下 : 新 建 一 个 网 站 ,默认 主页 为 Default. aspx。 添 加 1 个 
GridView 控件 。 首 先 , 将 GridView 控件 的 AllowPaging 属性 设置 为 True, 表 示人 允许 分 页 。 
然后 ,将 PageSize 属性 设置 一 个 数字 ,用 来 控制 每 个 页 面 中 显示 的 记录 个 数 ,这 里 设 为 4。 
再 使 用 SqlDataSource 数据 源 控件 来 配置 数据 源 。 最 后 ,重新 绑 定 GridView 控件 即 可 。 

实例 运行 效果 如 图 7. 18 所 示 。 
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图 启用 分 页 图 控件 分 页 实例 


7.3.7 在 GridView 控件 中 实现 全 选 和 全 不 选 功能 


在 管理 网 站 或 在 购物 车 中 ,需要 对 所 有 信息 或 商品 进行 操作 时 ,通常 是 使 用 一 个 全 选 的 
CheckBox 控件 来 实现 这 些 操作 。 下 面 实例 利用 这 个 全 选 的 CheckBox 控件 实现 全 选 或 全 
消 的 功能 。 

程序 实现 的 主要 步骤 如 下 。 

COD 新 建 一 个 网 站 ,默认 主页 为 Default. aspx。 添 加 1 个 GridView 控件 和 1 个 
CheckBox 控件 。CheckBox 控件 的 AutoPostBack 属性 设 为 True。 代 码 如 下 : 


«asp:CheckBox ID= "CheckBox1l" runat="server" AutoPostBack- "True" /> &nbsp; 
«asp:GridView ID- "GridViewl" runat="server"> 


< /asp:GridView» 


(2) 添加 一 个 SqlDataSource 控件 ,配置 数据 源 。 
(3) 首先 为 GridView 控件 添加 一 列 模板 列 , 然 后 向 模板 列 中 添加 CheckBox 控件 。 
GridView 控件 的 设计 代码 如 下 : 


«asp:GridView ID- "GridViewl" runat- "server"> 
«Columns» 
«asp:TemplateField HeaderText- "选择 "> 
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< ItemTemplate> 
<asp:CheckBox ID- "CheckBox2" runat="server" Text- "选择 " /> 
« /ItemTemplate^ 
< /asp:TemplateField» 
< /Columns» 
< /asp:GridView» 


(4) 设置 GridView 控件 的 数据 源 为 SqlDataSourcel ,并且 把 绑 定 字 段 都 设置 好 。 代 码 
AT: 


«asp:GridView ID- "GridViewl" runat="server" AutoGenerateColumns- "False" DataKeyNames- "stu 
. id" DataSourceID- "SqlDataSourcel"» 
«Columns» 
«asp:TemplateField HeaderText- "选择 "> 
« ItemTemplate» 
«asp:CheckBox ID- "CheckBox2" runat="server" Text- "选择 " /> 
« /ItemTemplate» 
< /asp:TemplateField» 
«asp:BoundField DataField- "stu id" HeaderText- "学 号 " ReadOnly- "True" 
SortExpression- "stu id" /» 
«asp:BoundField DataField- "stu name" HeaderText- "l/L 44 " SortExpression- 
"stu name" /> 
«asp:BoundField DataField- "stu age" HeaderText- "年 龄 " SortExpression- 
"stu age" /» 
«asp:BoundField DataField- "stu sex" HeaderText- "性 别 " SortExpression- 
"stu sex" /> 
< /Columns» 
< /asp:GridView» 


(5) 主要 程序 代码 。 

改变 “全 选 " 复 选 框 的 选项 状态 时 ,将 循环 访问 GridView 控件 中 的 每 一 项 ,并 通过 
FindControl 方法 搜索 TemplateField 模板 列 中 ID 为 CheckBox2 的 CheckBox 控件 ,并 建立 
该 控件 的 引用 ,实现 全 选 / 不 全 选 功能 。 在 CheckBoxl 控件 中 有 CheckedChanged 事件 ,在 
CheckedChanged 事件 中 编写 代码 如 下 : 


protected void CheckBoxl CheckedChanged (object sender, EventArgs e) 
( for (inti -0; i «-GridViewl.Rows.Count -1; i++) 
{ // 建 立 模 板 列 中 cneckBox 控件 的 引用 
CheckBox cb = (CheckBox) GridViewl.Rows [i] .FindControl ("CheckBox2") ; 
if (CheckBoxl.Checked -- True) 
{  cb.Checked - True; 
} 
else 


{ cb.Checked =False; 


运行 实例 , 单 击 全 选 所 有 信息 的 CheckBox 控件 为 选中 状态 ,如 图 7. 19 Brzn 


ET 


所 选择 xx0002 王 五 17 5 
区 选择 >x0003 小 惠 17 女 


| 号 选择 sx0004 笑 笑 16 x 


控件 中 实现 全 选 和 全 不 选 功能 


7.3.8 在 GridView 控件 中 对 数据 进行 编辑 操作 


在 GridView 控件 的 按钮 列 中 包括 "编辑 >“ 更 新 "“ 取 消 ” 按 钮 ,这 3 个 按钮 分 别 触发 
GridView 控件 的 RowEditing, RowUpdating, RowCancelingEdit 事件 ,从 而 完成 对 指定 项 
的 编辑 、 更 新 和 取消 操作 的 功能 。 下 面 实例 利用 GridView 控件 的 RowCancelingEdit, 
RowEditing 和 RowUpdating 事件 ,对 指定 项 的 信息 进行 编辑 操作 。 

程序 实现 的 主要 步 又 如 下 。 

CD 新 建 一 个 网 站 ,默认 主页 为 Default. aspx。 添 加 1 个 GridView 控件 和 1 个 
SqlDataSource 控件 。 

(2) 配置 SqlDataSource 控件 ,在 配置 的 时 候 一 定 要 把 高 级 部 分 选中 ,如 图 7. 20 所 示 。 


高 级 SQL 生成 选项 


图 选中 高 级 ”生成 选项 


(3) 设置 GridView 控件 的 数据 源 为 SqlDataSourcel, 并 且 编 辑 GridView 控件 绑 定 字 
段 ,使 结果 显示 如 图 7. 21 所 示 。 
(4) 选中 GridView 控件 ,选择 菜单 中 的 “启用 编辑 " 复 选 框 和 “启用 删除 ” 复 选 框 , 即 可 
实现 编辑 和 删除 功能 ,如 图 7. 22 所 示 。 
(5) 最 终 运行 结果 如 图 7. 23 所 示 。 
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图 控件 实现 编辑 功能 


7.4 DataList 控件 


DataList 控件 可 以 显示 模板 定义 的 数据 绑 定 列表 ,其 内 容 可 以 通过 使 用 模板 进行 控制 。 
通过 使 用 DataList 控件 ,用 户 可 以 显示 、 选 择 和 编辑 多 种 不 同 数据 源 中 的 数据 。 本 节 讨 论 如 何 
使 用 DataList 控件 进行 分 页 ,查看 数据 的 详细 信息 ,使 用 DataList 绑 定 数据 源 等 一 些 功能 。 


7.4.1 DataList 控件 概述 


DataList 控件 可 以 使 用 模板 和 定义 样式 来 显示 数据 ,并 进行 数据 的 选择 、 删 除 ,以 及 编 
辑 。DataList 控件 最 大 的 特点 是 一 定 要 通过 模板 来 定义 数据 的 显示 格式 。 要 设计 出 美观 的 
界面 ,就 需要 花费 一 番 心 思 。 正 因为 如 此 ,DataList 控件 显示 数据 时 却 更 具 灵 活性 ,开发 人 
员 个 人 发 挥 的 空间 比较 大 。DataList 控件 支持 的 模板 如 下 。 

1. AlternatingItemTemplate 

如 果 已 定义 , 则 为 DataList 中 的 交替 项 提供 内 容 和 布局 ;如 果 未 定义 , 则 使 用 ItemTemplate 。 

2. EditItemTemplate 

如 果 已 定义 , 则 为 DataList 中 当前 编辑 项 提供 内 容 和 布局 ;如 果 未 定义 , 则 使 用 
ItemTemplate。 
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3. FooterTemplate 

如 果 已 定义 , 则 为 DataList 的 脚注 部 分 提供 内 容 和 布局 ;如 果 未 定义 ,将 不 显示 脚注 
部 分 。 

4. HeaderTemplate 

如 果 已 定义 , 则 为 DataList 的 页 眉 节 提供 内 容 和 布局 ;如 果 未 定义 ,将 不 显示 页 眉 节 。 

5. ItemTemplate 

ItemTemplate JJ DataList 中 的 项 提供 内 容 和 布局 所 要 求 的 模板 。 

6. SelectedltemTemplate 

如 果 已 定义 , 则 为 DataList 中 当前 选 定 项 提供 内 容 和 布局 :如果 未 定义 , 则 使 用 
ItemTemplate。 

7. SeparatorTemplate 

如 果 已 定义 , 则 为 DataList 中 各 项 之 间 的 分 隔 符 提 供 内 容 和 布局 ;如 果 未 定义 ,将 不 显 
示 分 隔 符 。 


7.4.2 DataList 控件 常用 的 属性 、 方 法 和 事件 


下 面 对 常 用 的 属性 进行 详细 介绍 。 

1. DataKeyFiled 

DataKeyFiled 属性 指定 由 DataSource 属性 指示 的 数据 源 中 的 键 字段 。 键 字段 是 数据 
表 中 唯一 的 字段 ,一 般 情况 下 使 用 这 个 字段 做 索引 。 所 指定 的 字段 用 于 填充 DataKeys 集 
合 。 可 以 用 数据 列表 控件 存储 键 字段 而 无 须 在 控件 中 显示 它 。 

2. DataKeys 

使 用 DataKeys 集合 访问 数据 列表 控件 中 每 个 记录 的 键 值 ( 显 示 为 一 行 )。 这 样 可 以 用 
数据 列表 控件 存储 键 字段 而 无 须 在 控件 中 显示 它 。 此 集合 自动 用 DataKeyField 属性 指定 
的 字段 中 的 值 填充 。 

下 面 对 常用 的 方法 进行 详细 介绍 。 

FindControl 方法 

FindControl 方法 是 在 当前 的 命名 容器 中 搜索 指定 的 服务 器 控件 。 该 方法 在 DataList 
控件 或 GridView 控件 中 会 经 常用 到 。 

例如 ,在 DataList 控件 中 查找 ID 为 TextBoxName 的 TextBox 控件 的 Text 属性 值 使 
用 如 下 代码 ，: 

String Name = ( (TextBox)e.Item.FindControl ("TextBoxName")).Text; 

下 面 对 常 用 的 事件 进行 详细 介绍 。 

(1) EditCommand 事件 

对 DataList 控件 中 的 某 个 项 单 击 Edit 按钮 时 发 生 EditCommand 事件 。 

(2) UpdateCommand 事件 

对 DataList 控件 中 的 某 个 项 单 击 Update 按钮 时 发 生 UpdateCommand 事件 。 

(3) DeleteCommand 事件 

对 DataList 控件 中 的 某 个 项 单 击 Delete 按钮 时 发 生 DeleteCommand 事件 。 
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(4) CancelCommand 事件 
对 DataList 控件 中 的 某 个 项 单 击 Cancel 按钮 时 发 生 CancelCommand 事件 。 


7.4.3 使 用 DataList 控件 绑 定 数据 源 


DataList 控件 绑 定数 据 源 的 方法 与 GridView 控件 基本 相似 ,但 要 将 所 绑 定 数据 源 的 
数据 显示 出 来 ,这 需要 通过 设计 DataList 控件 的 模板 来 完成 。 下 面 示例 介绍 了 如 何 使 用 
DataList 控件 的 模板 显示 绑 定 的 数据 源 数据 。 

程序 实现 的 主要 步骤 如 下 。 

CD 新 建 一 个 网 站 ,默认 主页 为 Default. aspx。 添 加 1 个 DataList 控件 。 

(2) 单 击 DataList 控件 右上 方 的 国 按 钮 ,在 弹出 的 快捷 菜单 中 的 选择 “编辑 模板 ”选项 。 
打开 “DataList 任务 一 模板 编辑 模式 ”, 在 “显示 ”下 拉 列 表 框 中 选择 HeaderTemplate 选项 ， 
如 图 7. 24 所 示 。 

(3) 在 DataList 控件 的 页 眉 模 板 中 添加 一 个 表格 用 于 布局 和 显示 表 头 ,如 图 7. 25 所 示 。 

(4) 在 “DataList 任务 一 模板 编辑 模式 ”中 选择 ItemTemplate 选项 ,打开 项 模板 。 同 样 
在 项 模板 中 添加 一 个 用 于 布局 的 表格 ,并 添加 4 个 Label 控件 用 于 显示 数据 源 中 的 数据 记 
录 ,Label 控件 的 ID 属性 分 别 为 ID、Name、Sex 和 Age. WA 7. 26 所 示 。 
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(5) 单 击 ID 属性 名 为 ID 的 Label 控件 右上 角 的 “Label 加 ”标记 ,打开 “Label 任务 ” 快 
捷 菜 单 ,执行 “编辑 DataBindings” 命 令 ,打开 “ID DataBindings” 对 话 框 。 在 Text 属性 的 代 
码 表达 式 对 话 框 中 写 入 Eval("ID") ,用 于 绑 定数 据 源 中 的 ID 字段 ,如 图 7. 27 所 示 。 


选择 要 绑 定 到 | 的 必 性 ， 然 后 可 通过 选择 宇 段 来 关 定 它 。 也 可 使 用 自 定义 代码 表达 式 履 定 它 。 
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其 他 3 个 Label 控件 绑 定 方法 同上 。 以 上 设计 DataList 控件 的 源 代码 如 下 : 


«asp:DataList ID= "DataListl" runat="server"> 


< HeaderTemplate» 
«table» 
«tr» 
<td> 学 号 < /td> 
<td> 姓 名 < /ta> 
<td> 性 别 < /ta> 
<td> 年 龄 < /td> 
</tr> 
</table> 
< /HeaderTemplate> 
< ItemTemplate» 
<table> 
«tr» 
«td»«asp:Label ID- "ID" runat="server" Text='< $4 Eval ("stu id")£5 "> 
< /asp:label»« /td> 
«td»«asp:Label ID- "Name" runat="server" Text- '« $4 Eval ("stu name") $»' 
>< /asp:Label>< /td> 


«td» <asp:Label ID- "Sex" runat="server" Text- '<%#Eval ("stu sex") $>'></ 


asp:Label»«/td» 


«td» «asp:Label ID- "Age" runat="server" Text- '<%# Eval("stu age") $>'></ 


asp:Label»«/td» 
</tr> 
</table> 
</ItemTemplate> 


< /asp:DataList» 


(6) 在 “DataList 任务 一 模板 编辑 模式 ”中 单 击 * 结 束 模板 编辑 选项 ,结束 模板 编辑 。 
C) 自 定 义 方 法 BindO ,用 来 将 控件 绑 定 到 数据 源 ,代码 如 下 : 


protected void Bind() 


t 


// 实 例 化 Sai Connection 对 象 

string strConn =@"Data Source- .NSQLEXPRESS; 
Initial Catalog- Student; Integrated Security- True"; 
SqlConnection con =new SqlConnection (strConn); 
con.Open() ; 

// 实 例 化 Sal Command X1 

string strSql ="select * from T students"; 
SqlCommand com - new SqlCommand (strSql, con) ; 
SqlDataReader dr — com.ExecuteReader () ; 

// 绑 定 DataList 控件 的 数据 源 
DataListl.DataSource =dr; 
DataListl.DataBind(); 

dr.Close(); 
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con.Close(); 


} 
在 页 面 的 Page_Load 事件 里 调用 自 定义 方法 BindO ,代码 如 下 : 


protected void Page Load(object sender, EventArgs e) 
f if (!IsPostBack) 

{ Bind(); 

} 
} 


运行 实例 效果 如 图 7. 28 所 示 。 
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图 控件 绑 定 数据 源 


7.4.4 分 页 显示 DataList 控件 中 的 数据 


DataList 控件 并 没有 类 似 GridView 控件 中 与 分 页 相关 的 属性 ,那么 DataList 控件 是 
通过 什么 方法 实现 分 页 显示 呢 ? 其 实 很 简单 ,只 要 借助 PagedDataSource 类 来 实现 就 可 以 
了 ,该 类 封装 数据 绑 定 控件 与 分 页 相关 的 属性 ,以 允许 该 控件 执行 分 页 操作 。 下 面 实例 介绍 
了 如 何 使 用 PagedDataSource 类 实现 DataList 控件 的 分 页 功能 。 

程序 实现 的 主要 步骤 如 下 。 

CD 新 建 一 个 网 站 ,默认 主页 为 Default. aspx。 添 加 1 个 DataList 控件 、2 个 Label 控 
件 和 4 个 LinkButton 控件 。Label 控件 分 别 用 于 显示 当前 页 和 总 页 数 。LinkButton 控件 
分 别 用 于 显示 第 一 页 、 上 一 页 、 下 一 页 、 最 后 一 页 。 

(2) 主要 程序 代码 。 

页 面 加 载 时 调用 自 定义 方法 BindO 〇 .Bind0) 方 法 的 具体 代码 如 下 : 


protected void Bind() 
{ // 获 取 当前 页 码 
int curpage =Convert.ToInt32 (this.currentPage.Text); 
// 生 成 一 个 PagedDataSource 对 象 
PagedDataSource ps =new PagedDataSource () ; 
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string strConn =@"Data Source- .VSQLEXPRESS; Initial Catalog- Student; 
Integrated Security- True"; 
SglConnection con =new SqlConnection (strConn); 
con.Open() ; 
string strSql -"select * from T students"; 
SqlCommand comm — new SqlCommand (strSql, con); 
SqlDataAdapter odbA —new SqlDataAdapter (strSql, con); 
DataSet ds =new DataSet () 7 
odbA.Fill(ds, "students"); 
ps.DataSource -ds.Tables["students"].DefaultView; 
ps.AllowPaging - True; 
ps.PageSize -3; 
ps.CurrentPageIndex - curpage - 1; 
this.first.Enabled - True; 
this.front.Enabled - True; 
this.next.Enabled -True; 
this.last.Enabled - True; 
if (curpage 7-1) 
{ this.first.Enabled - False; 
this.front.Enabled - False; 
} 
if (curpage ==ps.PageCount) 
{ this.next.Enabled =False; 
this.last.Enabled =False; 
} 
this.totalPage.Text =Convert.ToString (ps.PageCount) ; 
this.DataListl.DataSource =ps; 
this.DataListl.DataBind(); 
con.Close(); 
} 


在 “首页 ”“ 上 一 页 ”“ 下 一 页 ”“ 尾 页 ”按钮 的 Click 事件 中 设置 当前 页 数 ,然后 重新 绑 
定数 据 , 代 码 如 下 : 


protected void first Click(object sender, EventArgs e) 
t 
currentPage.Text —Convert.ToString(1); 
Bind(); 
H 
protected void front Click (object sender, EventArgs e) 
t 
currentPage.Text —Convert.ToString (Convert.ToInt32 (currentPage.Text) -1); 
Bind; 
} 
protected void next Click (object sender, EventArgs e) 


currentPage.Text —Convert.ToString (Convert.ToInt32 (currentPage.Text) +1); 
Bind; 
} 
protected void last Click (object sender, EventArgs e) 
{ 
currentPage.Text =totalPage.Text; 
Bind; 
} 


在 页 面 的 Page Load 事件 里 调用 自 定义 方法 BindO ,代码 如 下 : 


protected void Page Load(object sender, EventArgs e) 
t 

if (!IsPostBack) 

{ BindQ; 

) 
) 


运行 实例 效果 如 图 7. 29 所 示 。 


二 DataLi st 控件 的 使 用 - Wicrosoft Internet Explor 
XED Bo SEV) IRO IAm "ho 


Qe O- i i3 oss vom e|O- 3 
MED [Eno Mieno oeeo oe Eea i 


学 号 姓名 性 别 年 龄 


xx0001 王 新 男 18 
xx0002 王 五 男 17 


xx0003 小 惠 女 17 
首页 上 一 页 下 一 页 尾 页 当前 页 码 为 ，[1] 页 总 页 码 为 ，[2] 页 


图 分 页 显示 控件 中 的 数据 


7.4.5 查看 DataList 控件 中 数据 的 详细 信息 


显示 被 选择 记录 的 详细 信息 可 以 通过 0 模板 来 完成 。 使 用 
SelectedItemTemplate 模板 显示 信息 时 ,需要 有 一 个 控件 激发 DataList 控件 的 
ItemCommand 事件 。 下 面 示例 介绍 了 如 何 使 用 SelectedItemTemplate 模板 显示 DataList 
控件 中 数据 的 详细 信息 。 

程序 实现 的 主要 步骤 如 下 。 

(1) 新 建 一 个 网 站 ,默认 主页 为 Default. aspx。 在 Default. aspx 页 中 添加 1 个 DataList 
控件 。 

(2) 打开 DataList 控件 的 项 模板 编辑 模式 。 在 ItemTemplate 模板 中 添加 1 个 
LinkButton 控件 ,用 于 显示 用 户 选 择 的 数据 项 ;在 SelectedItemTemplate 模板 中 添加 1 个 
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LinkButton 控件 和 4 个 Label 控件 ,分 别 用 来 取消 对 该 数据 项 的 选择 和 该 数据 项 详细 信息 
的 显示 。DataList 控件 的 属性 代码 如 下 : 


«asp:DataList ID= "DataListl" runat="server" 
onitemcommand- "DataListl ItemCommand"» 
< ItemTemplate» 
用 户 名 : <%#Eval ("stu name") $» 
«asp:Button ID- "Buttonl" runat="server" Text= "详细 信息 "CommandName= 
"select" /> 
</IterTemplate> 
«SelectedItemTemplate» 
«table border- "1"> 
«tr» 
<td> 学 号 : </td> 
<td><%#Eval ("stu id") $»« /td> 
</tr> 
<tr> 
<td> 姓 名 : < /ta> 
<td><%#Eval ("stu_name") $»« /td> 
</tr> 
<tr> 
«ta» ESI : < /td> 
<td><%#Eval ("stu sex") $»« /td> 
</tr> 
<tr> 
«td» flit : < /td> 
«td»«*4Eval("stu age") $»« /td> 
</tr> 
<tr> 
«td colspan= "2"> 
<asp:Button ID= "Button?" runat="server" Text= "返回 " CommandName- 
"back" /»« /td» 
«tr» 
</table> 
< /SelectedItemTemplate> 
« /asp:DataList» 


(3) 当 用 户 单 击 模板 中 的 按钮 时 ,会 引发 DataList 控件 的 ItemCommand 事件 ,在 该 事 
件 的 程序 代码 中 根据 不 同 按钮 的 CommandName 属性 设置 DataList 控件 的 SelectedIndex 
属性 的 值 ,决定 显示 详细 信息 或 者 取消 显示 详细 信息 。 最 后 ,重新 将 控件 绑 定 到 数据 源 , 代 
码 如 下 : 


protected void DataListl ItemCommand (object source, DataListCommandEventArgs e) 
( if (e.CommandName == "select") 
( DataListl.SelectedIndex —e.Item.ItemIndex; 
sOy 


Bind; 
} 
if (e.CommandName == "back") 
t 
DataListl.SelectedIndex =- 1; 
Bind; 


} 
(4) Bind 函数 跟 Page load PRECII ADT : 


protected void Page Load(object sender, EventArgs e) 
( if (!IsPostBack) 
{ Bind(); 
} 
} 
protected void Bind() 
{ string strConn =@"Data Source- .VSQLEXPRESS; Initial Catalog- Student; 
Integrated Security- True"; 
SqlConnection con - new SqlConnection (strConn); 
con.Open() ; 
string strSql -"select * from T students"; 
SqlCommand comm - new SqlCommand (strSql, con); 
SqlDataReader dr; 
dr —-comm.ExecuteReader () ; 
DataListl.DataSource =dr; 
DataListl.DataBind(); 
dr.Close(); 
con.Close(); 
} 


运行 实例 , 单 击 学 生 姓名 则 显示 学 生 的 详细 信息 ,效果 如 图 7. 30 和 图 7. 31 所 示 。 
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7.4.6 在 DataList 控件 中 对 数据 进行 编辑 操作 


DataList 控件 中 也 可 以 像 GridView 控件 一 样 ,为 特定 项 进行 编辑 操作 。 在 DataList 
控件 中 是 使 用 EditItemTemplate 模板 实现 这 一 功能 的 。 下 面 示 例 介 绍 了 如 何 使 用 
EditItemTemplate 模板 对 DataList 控件 中 的 数据 项 进行 编辑 。 


程序 实现 的 主要 步骤 如 下 。 
CD 新 建 一 个 网 站 ,默认 主页 为 Default. aspx。 在 Default. aspx 页 中 添加 1 个 DataList 
控件 。 


(2) 打开 DataList 控件 的 项 模板 编辑 模式 。 在 ItemTemplate 模板 中 添加 1 个 Label 
控件 和 1 个 Button 控件 ;在 EditItemTemplate 模板 中 添加 2 个 Button 控件 、1 个 Label 控 
件 和 3 个 TextBox 控件 ,代码 如 下 : 


«asp:DataList ID= "DataListl" runat="server" 
oncancelcommand- "DataListl CancelCommand" 
oneditcommand- "DataListl EditCommand" 
onupdatecommand- "DataListl UpdateCommand" OnDeleteCommand- 
"DataListl DeleteCommand"» 
< ItemTemplate» 
姓名 : <%#Eval ("stu name") $> 
«asp:Button ID- "Buttonl" runat="server" Text- "编辑 " CommandName- "edit" /> 
</ItemTemplate> 
<EditItemTemplate> 
«table»«tr»«td» %4 </td> 
«td»«asp:TextBox ID- "tid" runat="server" Text='< $f Eval ("stu id") 人 "> 
< /asp:TextBox»« /td> < /tr> 
<tr><td> 姓 名 < /td> 
«td»«asp:TextBox ID- "tname" runat="server" Text- '< %#Eval 
("stu name") $5 '>< /asp:TextBox»« /td> 
eft 
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«tr» «td» fESI« /ta» 
«td»«asp:TextBox ID- "tpwd" runat="server" Text- '« $$ Eval 
("stu sex") $5 '»«/asp:TextBox»« /td> 
«/tr» 
<tr><td> 年 龄 < /td> 
«td»«asp:TextBox ID= "TextBox1l" runat="server" Text- '«$4Eval 
("stu age") $> '»« /asp:TextBox»« /td> 
</tr> 
<tr><td><asp:Button ID="Button2" runat="server" Text= "更 新 " 
CommandName- "update" />< /td> 
<td><asp:Button ID= "Button3" runat- "server" Text= "取消 " 
CommandName- "cancel" /> 
«asp:Button ID- "Button4" runat- "server" Text- "删除 " 
ComnandName- "delete"/» 
« /td» 
</tr> 
</table> 
< /EditItemTemplate> 
< /asp:DataList» 


注意 :“ 编 辑 ” 按 钮 控件 的 CommandName 属性 一 定 要 设置 为 edit 才能 引发 
EditCommand 事件 ,同样 “更 新 ”按钮 和 “取消 ”按钮 的 CommandName 属性 也 要 分 别 设置 为 
update, cancel 才能 引发 UpdateCommand 事件 和 CancelCommand 事件 。 

(3) 主要 程序 代码 。 

当 用 户 单 击 “ 编 辑 ” 按 钮 时 ,将 触发 DataList 控件 的 EditCommand 事件 。 在 该 事件 的 
处 理 程序 中 ,将 用 户 的 选中 的 项 设置 为 编辑 模式 ,代码 如 下 : 


protected void DataListl EditCommand (object source, DataListCommandEventArgs e) 
1 // 设 置 DataListl 控 件 的 编辑 项 的 索引 为 选择 的 当前 索引 值 
DataListl.EditItemIndex —e.Item.ItemIndex; 
Bind(); .— // 重 新 绑 定 DataList 控件 
) 


在 编辑 模式 下 , 当 用 户 单 击 “ 更 改 ” 按 钮 时 .将 触发 DataList 控件 的 UpdataCommand 事 
件 。 在 该 事件 的 处 理 程序 中 ,将 用 户 的 更 改 更 新 到 数据 库 , 并 取消 编辑 状态 ,代码 如 下 : 


protected void DataListl UpdateCommand (object source, DataListCommandEventArgs e) 
{ string i -DataListl.DataKeys[e.Item.ItemIndex].ToString(); 
string name, age,sex; 
name = ( (TextBox) e. Item.FindControl ("tname")) .Text; 
age = ((TextBox)e.Item.FindControl ("tAge")).Text; 
sex = ((TextBox)e.Item.FindControl ("tSex")).Text; 
string strSql — "update T students set stu name- '" «name +"',stu age- '" tage +"', 
stu sex-'" sex t+" where stu id- "i -c"'"; 
string strConn =@"Data Source- .NVSQLEXPRESS; Initial Catalog- Student; 
Integrated Security- True"; 


* 100 。 


SqlConnection con =new SqlConnection (strConn); 
con.Open() ; 
SqlCommand comm =new SqlCommand (strSql, con); 
comm. ExecuteNonQuery () 7 
con.Close(); 
DataListl.EditItemIndex = 一 17 
Bind() 7 
} 


当 用 户 单 击 “ 取 消 ” 按 钮 时 ,将 触发 DataList 控件 的 CancelCommand 事件 。 在 该 事件 
的 处 理 程序 中 ,取消 处 于 编辑 状态 的 项 ,并 重新 绑 定 数据 ,代码 如 下 : 


protected void DataListl CancelCormand (object source, DataListCommandEventArgs e) 
( DataListl.EditItemIndex --1; ”// 取 消 编辑 

Bind(); 
} 


在 页 面 Page Load 事件 中 调用 自 定义 的 方法 BindO ,Bind() 方 法 用 来 绑 定 DataList 控 
件 的 数据 源 , 代 码 如 下 : 


protected void Bind() 
{ string strConn - "Data Source- .VSQLEXPRESS; Initial Catalog- Student; Integrated Security 
-True"; 
SqlConnection con -new SqlConnection (strConn); 
con.Open () ; 
string strSql -"select * from T students"; 
SqlCommand comm =new SqlCommand(strSql, con); ”// 创 建 command 对 象 
SqlDataReader dr; 
dr -comm.ExecuteReader();  //command 对 象 执行 相应 的 SQL 语句 ,并 把 执行 的 结果 存在 
//dr 对象 中 
DataListl.DataSource -dr; // 设 置 DataList 控件 的 数据 源 
DataListl.DataKeyField ="stu id"; 
DataListl.DataBind(); // 实 现 数据 绑 定 
dr.Close(); 
con.Close(); 
} 


注意 : DataList 控件 在 绑 定 数据 时 ,应 先 将 DataKeyField 属性 设置 为 数据 表 的 主键 。 
在 程序 中 ,可 以 由 DataKeys 集合 利用 索引 值 取得 各 数据 的 索引 值 。 


7.4.7 获取 DataList 控件 中 控件 数据 的 方法 


在 使 用 DataList 控件 开发 网 站 时 ,经 常 需要 获取 DataList 控件 中 的 数据 ,开发 人 员 可 
以 使 用 FindControl ) 方 法 来 获取 DataList 控件 中 的 数据 。 例 如 使 用 DataList 控件 显示 商 
品 信息 , 当 想 要 修改 某 一 个 商品 数量 时 ,首先 选择 要 修改 的 商品 ,将 该 商品 的 数量 修改 ,修改 
后 使 用 FindControl() 方 法 获取 修改 后 的 数量 存储 到 数据 库 中 。 使 用 FindControl() 方 法 获 
取 商 品 数量 的 主要 代码 如 下 : 
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String Name- ( (TextBox) e. Item.FindControl ("TextBoxName")).Text; 


7.4.8 在 DataList 控件 中 创建 多 个 列 


在 DataList 控件 中 创建 多 个 列 ,只 要 将 DataList 控件 的 RepeatColumns 属性 设置 为 需 
要 显示 的 列 数 就 可 以 了 。 例 如 ,将 同一 字段 显示 为 2 列 , 把 DataList 控件 的 RepeatColumns 
属性 设置 为 2, 显示 如 图 7. 32 所 示 。 

注意 : DataList 控件 的 RepeatColumns 属性 是 用 来 设置 列 的 数目 ,本 实例 设置 为 3。 
RepeatDriection 属性 是 用 来 设置 列 的 方向 ,这 个 属性 有 两 个 值 : 一 个 是 Horizontal, 表 示 水 
平方 向 ; 另 一 个 是 Vertical ,表示 垂直 方向 ,本 实例 使 用 的 是 Horizontal。 
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图 控件 中 创建 多 个 列 


7.5 Repeater 控件 


Repeater 控件 使 用 列表 方式 来 显示 数据 ,能 够 让 用 户 定义 Template 模板 标记 ,自动 用 
模板 标记 的 项 目 , 像 循环 那样 重复 编排 数据 源 的 数据 ,其 基本 语法 如 下 : 


«asp:Repeater ID= "Repeaterl" runat- "server"> 
< HeaderTemplate» < /HeaderTemplate» 
« ItemTemplate» < /ItemTemplate» 
«AlternatingItemTemplate» « /AlternatingItemTemplate» 
< FooterTemplate» < /FooterTemplate» 

< /asp:Repeater» 


上 述 Repeater 控件 使 用 Template 模板 标记 (标记 内 容 可 以 使 用 HTML 标记 ) 编 排 数 
据 。 各 种 Template 标记 的 说 明 如 表 7. 2 所 示 。 


表 7.2 Template 标记 的 说 明 


Template 模板 标记 说 明 


定义 列表 项 目 , 也 就 是 重复 显示 部 分 ,对 于 数据 表 来 说 是 每 条 记录 ,此 为 必 
需 标记 

项 目 交 又 使 用 不 同样 式 的 模板 ,例如 ,记录 轮流 使 用 不 同色 彩 显示 ,可 以 定 
AlternatingltemTemplate | 义 此 标记 ,奇数 项 目 ( 以 0 开始 ) 使 用 此 模板 显示 ,偶数 项 目 使 用 
ItemTemplate 模板 


ItemTemplate 
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pr 


Template 模板 标记 说 明 

ee 项 目 分 隔 模板 ,可 以 定义 分 隔 标 记 , 通 常 使 用 HTML HRE <br> R <hr>, 
iab cad 如 果 没 有 定义 就 不 显示 

定义 列表 标题 ,对 数据 表 来 说 ,就 是 一 table 之 和 记录 的 标题 列 , 如 果 没 有 定 
HeaderTemplate pape 

义 就 不 显示 

定义 列表 脚注 ,对 数据 表 来 说 ,就 是 结尾 标记 二 /table> ,如果 没有 定义 就 不 
FooterTemplate 显示 


7.5.1 Repeater 控件 以 表格 显示 数据 表 


Repeater 控件 的 功能 如 同 Foreach 语句 , 换 句 话说 ,配合 HTML 表格 标记 和 数据 源 控 
件 , 就 可 以 使 用 表格 来 显示 数据 表 的 记录 数据 。 

Repeater 控件 首先 显示 HeaderTemplate 后 , 依 数据 表 的 记录 数 重复 显示 
ItemTemplate 和 AlternatingItemTemplate 模板 中 定义 的 内 容 , 最 后 显示 FooterTemplate 
模板 标记 的 内 容 。 

在 二 td 二 标记 中 每 个 单元 格 使 用 二 %# % 二 符号 标记 为 表达 式 , 此 例 是 获取 和 显示 指 
定数 据 表 字段 内 容 ,代码 如 下 : 


< %# Eval ("stu_name") $> 
上 述 程序 代码 的 参数 字符 串 是 数据 表 的 字段 名 称 。Default. aspx 页 面具 体 代码 如 下 : 


«asp:Repeater ID= "Repeaterl" runat="server"> 
< HeaderTemplate» 
«table» 
«tr bgcolor- "# ffcc99"» 
<td> 学 号 < /td> 
<td> 姓 名 < /td> 
<td> 年 龄 < /td> 
<td> 性 别 < /ta» 
</tr> 
< /HeaderTemplate» 
< ItemTemplate> 
<tr> 
«td»«*4Eval("stu id") $»«/td» 
«td»«5*4Eval("stu name") $»« /td> 
«td»«$4 Eval ("stu age") $»«/td» 
«td»«$f£Eval("stu sex") $>< /td> 
</tr> 
</ItemTemplate> 
<AlternatingItemTemplate> 
<tr bgcolor= "# dadfdd"> 
<td><%#Eval ("stu id") $></td> 
<td> < %# Eval ("stu name") %>< /td> 
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<td><%# Eval ("stu age") $»« /td» 
«td»«$4Eval("stu sex") $>< /td> 
</tr> 
< /AlternatingItemTemplate» 
< FooterTemplate> 
</table> 
< /FooterTemplate> 
< /asp:Repeater> 


Default. aspx. cs 页 面 代码 如 下 : 


protected void Page Load(object sender, EventArgs e) 
t 
string strConn - "Data Source- .VSQLEXPRESS; Initial Catalog- Student; 
Integrated Security- True"; 
SqlConnection con - new SqlConnection (strConn); 
con.Open () 7 
string strSql -"select stu id,stu name,stu sex,stu age from T students"; 
SqlCommand comm - new SqlCommand (strSql, con); 
SqlDataReader dr; 
dr —-comm.ExecuteReader () ; 
Repeaterl.DataSource -dr; 
Repeaterl.DataBind(); 
dr.Close(); 
con.Close(); 
) 


最 终 的 运行 结果 如 图 7. 33 所 示 。 
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图 控件 的 运行 结果 


7.5.2 Repeater 控件 分 页 显示 数据 表 中 数据 


以 上 实例 中 也 介绍 过 分 页 显示 数据 的 方法 ,但 是 那些 都 是 把 数据 库 中 的 数据 都 全 部 
查询 出 来 ,再 计算 显示 那个 部 分 ,然后 进行 显示 ,这 样 做 的 葡 端 就 是 如 果 数 据 库 中 表 中 的 
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数据 非常 庞大 ,分 页 显示 的 效率 就 会 很 低 , 导 致 显示 数据 过 慢 , 最 终 会 让 客户 放弃 浏览 
网 页 。 

现在 介绍 的 新 的 一 种 分 页 思想 ,仅仅 到 数据 库 中 把 需要 显示 的 记录 查询 出 来 ,这 样 显示 
的 速度 会 非常 快 ,不 会 导致 网 页 的 瘫痪 。 

pageTest. aspx 的 代码 如 下 : 


<asp:Repeater ID- "Repeaterl" runat="server"> 
«HeaderTemplate» 
«table» 
«tr bgcolor= "4 ffcc99"» 
«td» id« /td> 
<td> 姓 名 < /td> 
<td> 性 别 < /td> 
<td> 年 龄 < /ta» 
</tr> 
< /HeaderTemplate» 
< ItemTemplate> 
<tr> 
<td>< %#Eval ("stu id") $>< /td> 
<td><%#Eval ("stu name") $»« /td> 
<td><%#Eval ("stu sex") $></td> 
<td><%#Eval ("stu age") $></td> 
</tr> 
</ItemTemplate> 
«AlternatingItemTemplate» 
«tr bgcolor= "4 dadfdd"» 
<td><%#Eval ("stu id") $>< /td> 
«td» «5*4 Eval ("stu name") $»« /td> 
<td><%#Eval ("stu sex") $»«/td» 
«td»«5*4 Eval ("stu age") $»« /td> 
</tr> 
« /AlternatingItemTemplate» 
< FooterTemplate» 
</table> 
< /FooterTemplate> 
< /asp:Repeater> 
<asp:Label ID- "Labell" runat="server" Text="">< /asp:Label» 
<asp:HyperLink ID- "first" runat="server"> 55 — Ji < /asp:HyperLink> 
«asp:HyperLink ID- "front" runat="server"> L — J < /asp:HyperLink» 
«asp:HyperLink ID- "next" runat="server"> | — W< /asp:HyperLink» 
«asp:HyperLink ID- "last" runat="server"> — Ji < /asp:HyperLink» 


pageTest. aspx. cs 的 代码 如 下 : 


protected void Page Load(object sender, EventArgs e) 
{ int cpage; 
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if (Request.QueryString["page"] !-null) 

cpage —Convert.ToInt32 (Request .QueryString|["page"]) ; 
else 

cpage 71; 
int pagesize -2; 


string sql = 


string myConnString = ("Data Source- . V SQLEXPRESS; Initial Catalog- Student; Integrated 
Security- True"; 

SqlConnection con - new SqlConnection (myConnString); 

con.Open() ; 

string strSql -"select count(* ) from T students"; 

SqlCommand com - new SqlCommand (strSql, con); 

int totalput —Convert.ToInt32 (com.ExecuteScalar () ) ; 

int maxpage =1; 

if (totalput $pagesize ==0) 

{ maxpage -totalput / pagesize; 


else 


maxpage —totalput / pagesize +1; 


if (maxpage ==0) { maxpage 71; } 
if (cpage «1) 

cpage 71; } 

else if (cpage >maxpage) 

cpage =maxpage; } 

if (totalput !=0) 

{ 


if (cpage ==1) 

{ sql="select top "+pagesize +" * from T students order by stu id desc"; 

H 

else 

{ sql -"select top " *pagesize +" * from T students where stu id not 
in(select top " * (cpage -1) * pagesize *" stu id from T students order 
by stu id desc) order by stu id desc"; 


H 

com.CommandText = sql; 

SglDataReader dr; 

dr —com.ExecuteReader () ; 

this.Labell.Text — "共有 信息 "+totalput.Tostring() +" 条 当前 是 第 "+ 

cpage.ToString () +"/" +maxpage.Tostring() +" 页 "; 

if (cpage !-1) 

t 
this.first.NavigateUrl = "pageTest.aspx?page- 1"; 
this.front.NavigateUrl ="pageTest .aspx?page- " 4 Convert .'ToString (cpage -1); 
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H 

if (cpage !—-maxpage) 

t 
this.next.NavigateUrl = "pageTest .aspx?page- " * Convert .ToString (cpage +1); 
this.last.NavigateUrl = "pageTest.aspx?page- " -maxpage.ToString(); 

H 

this.Repeaterl.DataSource =dr; 

this.Repeaterl.DataBind(); 

H 


7.6 小 结 


本 章 主要 介绍 数据 控件 的 使 用 ,第 6 章 讲 述 的 处 理 数 据 库 中 的 数据 ,处 理 完毕 后 如 何 显 
示 在 页 面 当 中 ,就 是 用 到 的 本 章 讲述 的 数据 控件 。 使 用 数据 控件 可 以 把 想 显示 的 内 容 显 示 
处 理 , 同 时 可 以 进行 数据 库 的 操纵 。 


课 后 思考 问题 


1. GridView 控件 .DataList 控件 和 Repeater 控件 三 者 之 间 的 区 别 是 什么 ?从 网 站 的 
执行 效率 方面 考虑 ,这 3 个 控件 如 何 能 更 好 地 使 用 ? 

2. 除了 课本 上 介绍 的 查询 显示 方式 外 ,分 页 显示 查询 信息 有 没有 更 高 效 的 分 页 显示 
方式 ? 


第 8 单 表 新 闻 发 布 系统 的 实现 


本 章 要 点 

。 需求 分 析 。 

。 功能 描述 。 

。 数据 库 说 明 。 

。 项 目 界 面 展示 。 
。 相应 的 主要 代码 。 


8.1 需求 分 析 


企业 网 站 .门户 网 站 和 个 人 网 站 等 ,多 数 地方 需 要 显示 新 闻 内 容 , 本 章 介绍 的 单 表 新 闻 
系统 ,就 是 想 让 读者 首先 接受 简单 的 网 站 的 建设 流程 ,使 读者 很 容易 地 了 解 网 站 的 制作 过 程 
和 包含 的 内 容 等 。 

单 表 新 闻 发 布 系统 的 主要 功能 为 新 闻 信 息 的 发 布 ,以 及 新 闻 信息 的 浏览 。 另 外 参考 其 
他 的 新 闻 发 布 系统 ,可 以 将 系统 分 为 两 部 分 : 一 个 为 后 台 管 理 部 分 ,一 个 为 前 台 显 示 部 分 。 
通过 后 台 管 理 部 分 来 进行 新 闻 数据 的 维护 ,通过 前 台 显 示 部 分 进行 新 闻 的 浏览 。 

本 系统 的 主要 功能 图 如 图 8. 1 所 示 。 


新 闻 发 布 系统 
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图 主要 功能 图 


8.2 新闻 标 题 显示 


首先 介绍 首页 中 新 闻 标题 的 显示 ,显示 的 结果 如 图 8. 2 所 示 。 

想 要 显示 新 闻 标 题 , 就 需要 到 数据 库 中 把 News 表 中 的 标题 都 查找 出 来 ,本 系统 使 用 三 
层 架 构 的 思想 ,把 对 于 数据 库 的 操纵 都 写 在 类 中 ,首先 新 建 一 个 类 NewsDB, 这 个 类 中 包含 
了 对 于 数据 库 所 有 的 操作 。 下 面 这 段 代 码 是 对 首页 中 要 显示 的 新 闻 标 题 的 操作 。 
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图 首页 新 闻 标 题 显 示 


public class NewsDB 
{ 
/// < sumary> 
/// 显示 新 闻 标 题 
///</summary> 
/// <returns> 新 闻 标题 列表 < /returns> 
public static IList« News» GetList () 
t 
// 获 取 连 接 对 象 的 连接 字符 串 
string strConn =ConfigurationManager.ConnectionStrings ["strConn2"].ConnectionString; 
// 建 立 连接 对 象 
SqlConnection conn =new SqlConnection (strConn); 
// 打 开 跟 数据 库 的 连接 
conn.Open () 
// 到 数据 库 中 检索 前 15 行 记录 
string strSql -"select top 15 id,title from [T news] order by id desc"; 
SqlCommand comm — new SqlCommand (strSql, conn); 
// 使 用 Command 对 象 执行 相应 SQL 语句 
SqlDataReader dr = comm.ExecuteReader () ; 
// 创 建 一 个 泛 型 
IList< News> newsTotal =new List<News> (); 
// 把 所 有 的 查询 结果 导 到 泛 型 中 
while (dr.Read()) 
t 
News newsl —new News () ; 
newsl.ID —-Convert.ToInt64 (dr["id"]); 
newsl.Title —Convert.ToString (dr["title"]); 
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newsTotal .Add (news1) ; 
} 
dr.Close(); 
conn.Close(); 
return newsTotal; 


) 


) 
对 数据 库 的 操作 处 理 完 后 ,就 需要 把 对 数据 库 的 操作 结果 在 首页 中 显示 出 来 ,显示 的 步 


又 如 下 。 
CD 在 首页 中 拖 动 一 个 ObjectDataSource 控件 ,下 面 配置 这 个 控件 的 属性 , 单 击 


ObjectDataSource 控件 右上 角 的 小 箭头 ,进行 配置 数据 源 , 如 图 8. 3 所 示 。 


asp:ObjectDataSources ObjectDataSou.. 
ObjectDataSource - ObjectDataSourcei |. ObjectD: 


E 配置 数据 源 


(2) 出 现 配置 数据 源 窗 口 后 ,在 选择 业务 对 象 中 选择 NewsDB, 也 就 是 上 面 建立 的 类 
NewsDB。 单 击 “ 下 一 步 ” 按 钮 ,如 图 8.4 所 示 。 


T X 


选择 可 以 用 于 检索 或 更 新 数据 的 业务 对 象 (例如 ， 在 此 应 用 程序 的 Bin 或 App Code 目录 中 定义 的 对 象 ). 


[NewsD8 z) D Roe) 


图 选择 业务 对 象 


(3) 在 出 现 的 定义 数据 方法 窗口 中 ,选择 方法 GetList() ,返回 IList News. RAH 
击 “ 完 成 ”按钮 即 可 ,如 图 8.5 所 示 。 

首页 中 的 数据 源 设 置 好 后 ,就 需要 把 结果 通过 控件 显示 在 页 面 上 。 这 个 控件 可 以 使 用 
Repeater 控件 ,也 可 以 使 用 DataList 控件 ,也 可 使 用 别 的 相应 的 数据 控件 ,这 里 使 用 


Repeater 控件 ,对 结果 进行 显示 。 
(1) 在 首页 相应 位 置 拖 动 一 个 Repeater 控件 , 单 击 Repeater 右上 角 的 箭头 ,进行 数据 
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图 定义 数据 方法 
源 的 选择 ,选择 好 数据 源 后 ,就 完成 了 新 闻 标 题 的 显示 ,如 图 8. 6 所 示 。 


图 控件 的 数据 源 设 置 
(2) Repeater 控件 中 的 重要 代码 如 下 所 示 。 


«div id= "main"> 
«div id= "tips"> 
<div id- "news"> 
<asp:Repeater ID= "Repeaterl" runat="server" DataSourceID- 
"ObjectDataSourcel"» 
< ItemTemplate» 
«ul» 
<li><a href- '«$$ Eval ("id", "NewsView.aspx?NewsID- (0)") $5» '» 
«$4 Eval ("title") $»«/a»«/li» 
</ul> 
</ItemTemplate> 
< /asp:Repeater> 
«asp:ObjectDataSource ID= "ObjectDataSourcel" runat="server" 
SelectMethod- "GetList" TypeName- "NewsDB"> < /asp:ObjectDataSource» 
«/div» 
«h4» « span» <a href- "NewsMore .aspx"» Wi 4& ---« /a» « /span»« /h4» 
« /div» 
+ Hx 


8.3 新 闻 具 体内 容 的 显示 


当 人 们 想 看 哪 条 具体 新 闻 的 时 候 ,需要 单 击 首页 中 的 新 闻 标 题 , 然 后 把 本 新 闻 的 主要 的 
内 容 显示 出 来 ,本 节 讲 述 这 部 分 的 实现 过 程 ,运行 结果 如 图 8.7 Brom 


学 期 前 全 院 教 职 工大 会 时 间 
发 布 时 间 : 11:41 
全 院 教 职 工大 会 于 2014 年 9 月 24 日 ( 周 五 ) 上 午 9 点 在 北 校区 大 礼堂 召开 ， 请 各 位 教 职 工 按时 参加 。 
新 闻 来 源 : 新 浪 


版 权 所 有 


图 新 闻 具 体内 容 显示 


首先 来 看 首页 Default. aspx 页 面 中 Repeater 控件 中 的 代码 到 1i 盖 二 a href —'—?6 # Eval 
("id", "NewsView. aspx?NewsID— (0) ") 962 77 «94 € EvalC" title") % ></a> </li>, 24 8f 
i orn ip 会 转 到 NewsView. aspx 这 个 页 面 中 , 转 去 这 个 页 面 后 地 址 后 面 连 
接 了 一 个 NewsID 这 么 一 个 属性 值 , 人 们 可 以 通过 取得 它 的 值 ,从 而 知道 用 户 到 底 想 看 哪 一 
条 新 闻 。 

看 相应 新 闻 也 是 需要 到 数据 库 中 去 查询 ,只 要 是 对 数据 库 的 操作 就 写 到 NewsDB 中 。 
重要 代码 如 下 : 


/// «sumnary» 

/// 根据 ID 查询 表 中 的 新 闻 

///</summary> 

/// «param name= "id"> 新 闻 ID< /param> 

/// <returns> 新 闻 对 象 < /returns> 

public static News GetNewsByID (long id) 

t 
string strConn -ConfigurationManager.ConnectionStrings ["strConn2"].ConnectionString; 
SqlConnection conn =new SqlConnection (strConn); 


conn.Open() ; 


string strSql -"select * from [T news] where id- eid"; 
SqlCommand comm =new SqlCommand (strSql, conn); 

comm. Parameters .AddWithValue ("e id", id); 

SqlDataReader dr = comm.ExecuteReader () ; 
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) 


显示 新 闻 内 容 的 页 面 使 用 了 母 版 ,显示 的 格式 跟 首 页 相似 ,其 中 主要 代码 如 下 : 


News newl —new News () ; 

while (dr.Read()) 

{ 
newl.ID =Convert.ToInt64 (dr["id"]); 
newl.Title —dr["title"].ToString(); 
newl.NewsContent —dr["newsContent"].ToString(); 
newl.NewsDate —Convert.ToDateTime (dr ["newsDate"]) ; 
newl.NewsSource -dr["newsSource"].ToString(); 

} 

dr.Close(); 

conn.Close(); 


return newl; 


«table style- "width:90$;margin:auto;"» 


<tr><td align- "right'» «a href- "Default.aspx"> 返 回 主页 </a>< /td» « /tr» 
<tr><td align="center"> 

<asp:Label ID= "newsTitle" runat- "server" Text="">< /asp:Label> 
</td></tr> 
<tr><td> 

<hr style="height :1px;" /> 
</td></tr> 
<tr><td align="right"> 

发 布 时 间 : <asp:Label ID= "newsDate" runat="server" Text="">< /asp:Label> 
</td></tr> 
<tr><td> 

<asp:Label ID= "newsContent" runat="server" Text="">< /asp:Label» 
</td></tr> 
<tr><td align="right"> 

新 闻 来 源 : <asp:Label ID= "newsSource" runat="server" Text="">< /asp:Label> 
</td></tr> 
</table> 


新 闻 显 示 的 . cs 代码 如 下 : 


protected void Page Load(object sender, EventArgs e) 


{ 


long id =Convert .ToInt64 (Request .QueryString ["NewsID"]); 
News newsById =new News () ; // 接 受 NewsDB 返回 的 结果 
if (Request.QueryString["NewsID"] ==null) 
t 
Response.Write ("< script>alert ('i f f¥ iğ ID {H !')</script>"); 
} 
else 


1 
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newsById = NewsDB .GetNewsByID (id); 

newsTitle.Text —newsById.Title.ToString(); 
newsDate.Text —newsById.NewsDate.ToShortTimeString(); 
newsContent.Text —newsById.NewsContent.ToString|(); 


newsSource.Text —newsById.NewsSource.ToString(); 


8.4 新 闻 检 索 功 能 


新 闻 检 索 就 是 到 数据 库 中 把 用 户 填写 的 相关 新 闻 都 查找 出 来 ,运行 的 页 面 如 图 8. 8 所 示 。 


a 


Xe d dk A 


ETIN 回 


图 首页 新 闻 检索 


新 闻 检 索 结果 显示 如 图 8.9 所 示 。 


五 一 放假 通知 
六 一 放假 通知 
寒假 放假 通知 
署 假 放 假 通知 


图 新 闻 检 索 结 果 显 示 


新 闻 检 索 对 于 数据 库 的 操作 代码 如 下 : 


/// «summary» 

/// 根据 新 闻 标 题 检索 数据 库 中 的 相应 数据 

/// </summary> 

/// «param name= "selectTile"> 查 询 的 标题 内 容 < /param> 

/// <returns> 新 闻 列 表 < /returns> 

public static IList« News» SelectNewsTitle (string selectTile) 

t 
string strConn -ConfigurationManager.ConnectionStrings ["strConn2"].ConnectionsString; 
SglConnection conn =new SqlConnection (strConn); 
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conn.Open (); 


string strSgl -"select id,title frm [T News] where title like '$" *selectTile &"$'"; 
//string strSql - "select id,title from [T News] where title like '$8title$'"; 


SqlCommand comm — new Sql Command (strSql, conn) ; 
/ /comm. Parameters .AddWithValue ("Gtitle", selectTile); 
SqlDataReader dr = comm.ExecuteReader () ; 


IList« News» SelectNews =new List«News» (); 
while (dr.Read()) 
t 
News newsl —new News () ; 
newsl.ID -Convert.ToInt64 (dr ["id"]); 
newsl.Title -dr["title"].ToString(); 
SelectNews .Add (news1) ; 


) 
dr.Close(; 


conn.Close(); 


return SelectNews; 
} 


对 于 新 闻 检 索 结 果 的 显示 ,方法 如 同 8. 2 章节 ,在 这 不 再 详细 介绍 。 


8.5 新 闻 后 台 登 录 页 面 实现 


前 面 介绍 了 部 分 重要 的 前 台 页 面 的 实现 ,本 节 介绍 后 台 的 登录 页 面 的 实现 ,实现 的 界面 
如 图 8. 10 所 示 。 


<7 


Mocha KoolPoint 


摩卡 酷 点 


图 登录 页 面 


注册 页 面 主要 代码 如 下 : 
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protected void Page Load(object sender, EventArgs e) 
t 
if (!IsPostBack) 
t 
if (Session["UserName"] !=null) 
{ 
Session.Abandon(); 


) 
if (IsPostBack) 
t 
if (Session["CheckCode"].ToString () -—-Request.Form["valid"].ToString ()) 
{ 
Login(); 
} 
else 
t 
this.ClientScript.RegisterStartupScript (this.GetType(), "aa", 
"<script>alert(" 验 证 码 不 对 ,请 重新 填写 !") ;< /script» ") ; 


) 

protected void Login () 

t 
string username -Request.Form["username"].ToString(); 
String password —-Request.Form["pwd"] .ToString(); 


if (username ==" || password == 
{ 


this.ClientScript.RegisterStartupScript (this.GetType () "aa", 
"< script» alert (' 用 户 名 或 密码 不 能 为 空 !') ;< /script» "); 


else 


if (username =="admin" && password == "123") 

t 
Session["UserName"] — "admin"; 
Response.Redirect ("AdminIndex.aspx"); 

} 

else 

{ 
this.ClientScript.RegisterStartupScript (this.GetType (), "aa", 
"< script»alert (' 用 户 名 或 密码 不 正确 !1');< /script» "); 
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8.6 添加 新 闻 


添加 新 闻 是 后 台 页 面 中 必需 的 部 分 ,动态 页 面 的 显示 就 是 需要 在 后 台 可 以 对 前 台 显 示 
的 内 容 进 行 操作 。 添 加 页 面 的 运行 结果 如 图 8. 11 所 示 。 


IE 新 闻 发 布 系统 后 台 管 理 页 面 


HINE: 


HER: 


图 后 台 添加 页 面 


后 台 添 加 页 面 也 是 需要 对 数据 库 中 的 表 进 行 添 加 ,所 以 操作 数据 库 的 代码 还 是 写 在 
NewsDB 中 ,主要 代码 如 下 : 


/// < summary» 

/// 添加 新 闻 

/// < /summary» 

/// «param name- "ne"> 表 单 上 填写 的 新 闻 内 容 < /param> 

/// <returns> 是 否 添加 成 功 < /returns> 

public static bool AddNews (News ne) 

t 
string strConn -ConfigurationManager.ConnectionStrings ["strConn2"].ConnectionString; 
SqlConnection conn =new SqlConnection (strConn); 
conn.Open() ; 


string strSql -"insert into [T News] (title, newsContent, newsSource) values (8title, 


content, 6source)"; 
SqlCommand comm =new SqlCommand (strSql, conn); 


comm. Parameters .AddWithValue ("Gtitle", ne.Title); 


e qi x 


) 


comm. Parameters .AddWithValue ("Gcontent", ne.NewsContent); 


comm. Parameters .AddWithValue ("Gsource", ne.NewsSource); 
int i —comm.ExecuteNonQuery () ; 

conn.Close(); 

if (i >0) 


{ 


return True; 


return False; 


添加 页 面 的 主要 代码 如 下 : 


<table> 
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«tr» 
<td> 新 闻 标题 : < /td> 
«td» 
<asp:TextBox ID- "txtTitle" runat- "server">< /asp:TextBox»« /td> 
<td> < /td> 
</tr> 
<tr> 
<td> 新 闻 内 容 : < /td> 
<td> 
«asp:TextBox ID= "txtContent" runat- "server" TextMode- "MultiLine" 
Height- "36lpx" Width- "497px"» « /asp:TextBox»« /td> 
<td> < /td> 
</tr> 
<tr> 
<td> 新 闻 来 源 : </td> 
<td> 
<asp:TextBox ID= "txtSource" runat- "server">< /asp:TextBox> < /td> 
<td>< /td> 
«/tr» 
«tr» 
«td» 
«asp:Button ID- "Buttonl" runat="server" Text- "添加 " onclick- 
"Buttonl Click" /»« /td» 
«td» 
«asp:Button ID- "Button?" runat="server" Text- "Hi 'É" onclick- 
"Button2 Click" />< /td> 


«td»«/td» 
«/tr» 


</table> 


后 台 添 加 页 面 的 . cs 页 面 的 代码 如 下 : 


protected void Buttonl Click (object sender, EventArgs e) 


t 


) 


News nl -new News () 7 

nl.Title -txtTitle.Text; 
nl.NewsContent -txtContent.Text; 
nl.NewsSource —txtSource.Text; 


bool flag —-NewsDB.AddNews (n1) ; 


if (flag -- True) 
{ 
this.ClientScript.RegisterStartupScript (this.GetType () "aa", 
"< script» alert (' 添 加 成 功 ');< /script» ") ; 
txtTitle.Text =""; 
txtContent.Text =""; 
txtSource.Text =""; 


txtTitle.Focus (); // 获 取 焦 点 


else 


this.ClientScript.RegisterStartupScript (this.GetType (), "aa", 
"< script» alert (' 添 加 不 成 功 !1') ;< /script>"); 


protected void Button2 Click(object sender, EventArgs e) 


t 


8.7 


txtTitle.Text =""; 


txtContent.Text 
txtSource.Text — 


编辑 新 闻 


编辑 页 面 就 是 对 数据 库 中 的 新 闻 表 进行 修改 和 删除 ,运行 页 面 如 图 8. 12 Bron 。 

编辑 页 面 首先 到 数据 库 中 把 所 有 的 记录 查找 出 来 ,进行 分 页 显示 ,然后 再 加 上 编辑 和 删 
除 两 个 功能 键 。 

对 于 数据 库 的 查询 ,主要 代码 如 下 : 
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« 市 系统 后 台 管 理 页 面 
ID 号 作品 一 
n Bs. 


全 一 
E C 


A 


图 编辑 页 面 


/// «sumnary» 

/// 获取 新 闻 表 中 的 所 有 记录 

/// </summary> 

/// <returns> 新 闻 标 题 列 表 < /returns> 

public static IList<News> GetAllList () 

t 
string strConn -ConfigurationManager.ConnectionStrings ["strConn2"].ConnectionString; 
SqlConnection conn =new SqlConnection (strConn); 
conn.Open () 7 


string strSql -"select id,title from [T news] order by id desc"; 
SqlCommand comm —- new SqlCommand (strSql, conn); 
SqlDataReader dr - comm.ExecuteReader () ; 


IList«News» newsAll =new List« News» (); 


while (dr.Read()) 

i 
News newsl —new News () ; 
newsl.ID —Convert.ToInt64 (dr["id"]); 
newsl.Title —-Convert.ToString (dr["title"]); 
newsAll.Add (news1) ; 


dr.Close(); 
conn.Close (); 


return newsAll; 
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) 
编辑 页 面 使 用 了 DataList 控件 来 实现 的 ,主要 代码 如 下 : 


«asp:DataList ID- "DataListl" runat="server" DataSourceID- "ObjectDataSourcel" 
Width- "90$" DataKeyField- "id" ondeletecommand- "DataListl DeleteCommand"» 
< HeaderTemplate» 

«table class- "smallLine" width- "100$"» 
«tr» 
«td class-"smallLine"» ID 5 « /td» 
«td class- "smallLine"> 新 闻 标题 < /td> 
«td class= "smallLine"> 编 辑 < /td> 
«/tr» 
< /HeaderTemplate» 
« ItemTemplate» 
«tr» 
«td class- "smallLine"» < $4 Eval ("id") $»« /td> 
«td class= "smallLine"» < %#Eval ("title")®%>< /td> 
«td class- "smallLine"» 
<a href= '« $f Eval ("id", "edit.aspx?newsID- (0)") $» "> 编辑 < /a> | 
«asp:LinkButton ID-"lbDelete" runat="server" CammandName- "delete" 
OnClientClick- "return confirm(' 确 定 要 删除 此 新 闻 吗 ?')"> 删 除 
< /asp:LinkButton» 
</td> 
SH 
</ItemTemplate> 
< FooterTemplate> 
</table> 
< /FooterTemplate> 
< /asp:DataList» 
<asp:ObjectDataSource ID= "ObjectDataSourcel" runat="server" 
SelectMethod- "GetAllList" TypeName- "NewsDB"> 
< /asp:ObjectDataSource» 


当 单 击 编辑 超 链接 时 , 转 到 edit. aspx 页 面 ,此 页 面 的 运行 结果 如 图 8. 13 所 示 。 
修改 页 面 需要 对 数据 库 中 的 信息 进行 修改 ,所 以 也 得 对 数据 库 操作 ,操作 的 代码 写 在 
NewsDB 类 中 ,主要 的 代码 如 下 : 


/// «summary» 
/// 编辑 新 闻 内 容 
/// < /summary» 
/// «param name= "ne"> 编 辑 好 的 新 闻 记 录 < /param> 
/// <returns> 是 否 编辑 成 功 < /returns> 
public static bool EditNews (News ne) 
t 
string strConn -ConfigurationManager.ConnectionStrings ["strConn2"].ConnectionsString; 


SqlConnection conn - new SqlConnection (strConn); 
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新 间 标 题 ; ”修改 后 的 添加 页 面 
修改 后 的 添加 贡 面 ， 把 页 画 添 加 完成 后 把 内 容 青空 了 ^ 


新 闻 内 容 : 


conn.Open () 7 


string strSql -"update [T News] set title-Gtitle,newsContent- (content, 
newsSource- (source where id- (id"; 

SqlCommand comm —- new SqlCommand (strSql, conn); 

comm. Parameters .AddWithValue ("Gtitle", ne.Title); 

comm. Parameters.AddWithValue ("Gcontent", ne.NewsContent); 

comm. Parameters .AddWithValue ("@source", ne.NewsSource); 

comm. Parameters .AddWithValue ("@id", ne.ID); 


int i —-comm.ExecuteNonQuery () ; 
conn.Close(); 
if (i >0) 


t 


return True; 


return False; 


) 
编辑 页 面 的 主要 代码 如 下 : 


«table» 
«tr» 
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<td> 新 闻 标题 : < /td> 
«td» 


<asp:TextBox ID- "txtTitle" runat- "server" « /asp:TextBox»« /td> 


<td>< /td> 

«/tr» 

«tr» 
<td> 新 闻 内 容 : </td> 
«td» 


«asp:TextBox ID- "txtContent" runat- "server" TextMode- "MultiLine" 


Height- "36lpx" Width- "497px"» « /asp:TextBox»« /td> 
«td»«/td» 
</tr> 
«tr» 
<td> 新 闻 来 源 : < /td> 
<td> 


<asp:TextBox ID= "txtSource" runat- "server">< /asp:TextBox> < /td> 


<td>< /td> 
</tr> 
«tr» 
«td» 
«asp:Button ID- "Buttonl" runat="server" Text- "修改 " onclick- 
"Buttonl Click" />< /td> 
«td» 
«asp:Button ID- "Button2" runat="server" Text- "if fi" onclick- 
"Button2 Click" /»«/td» 
«td»«/td» 
</tr> 
</table> 


编辑 页 面 的 . cs 代码 如 下 : 


protected void Page Load(object sender, EventArgs e) 
t 
if (!IsPostBack) // 第 一 次 加 载 时 读 取 数据 库 中 的 数据 
t 
long id -Convert.ToInt64 (Request .QueryString ["newsID"]); 
News newl —new News () ; 
newl —-NewsDB.GetNewsByID (id); 
if (newl --null) 
i 
this.ClientScript.RegisterStartupScript (this.GetType (), "aa", 
"< script>alert (' 没 有 查询 到 相应 记录 !');< /script» "); 


else 


txtTitle.Text —newl.Title; 
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txtContent.Text —newl.NewsContent; 


txtSource.Text —newl.NewsSource; 


protected void Buttonl Click (object sender, EventArgs e) 
t 
News newsl =new News () ; 
newsl.ID -Convert.ToInt64 (Request .QueryString["newsID"]) ; 
newsl.Title -txtTitle.Text; 
newsl.NewsContent —txtContent.Text; 
newsl.NewsSource —txtSource.Text; 


bool flag -NewsDB.EditNews (newsl) ; 


if (flag -- True) 
t 
this.ClientScript.RegisterStartupScript (this.GetType () "aa", 
"< script» alert ("fA il JJ] ') ; 1ocation- 'EditNews.aspx'« /script» "); 
) 
else 
{ 
this.ClientScript.RegisterStartupScript (this.GetType () "aa", 
"< script» alert (HAR IV JJ 1") ;< /script» "); 


) 
protected void Button2 Click(object sender, EventArgs e) 
t 
txtTitle.Text =""; 
txtContent.Text =""; 
txtSource.Text -""; 
) 


最 后 只 剩 下 删除 数据 库 中 的 信息 。 删 除 时 为 了 避免 误 删 ,首先 当 用 户 单 击 “ 删 除 ? 时 ,要 
求 询问 用 户 是 否 真 的 要 删除 此 记录 ,是 的 话 再 进行 删除 操作 ,主要 代码 如 下 : 


«asp:LinkButton ID= "lbDelete" runat="server" CommandName- "delete" 
OnClientClick- "return confirm(" 确 定 要 删除 此 新 闻 吗 ?')"> 删 除 
</asp:LinkButton> 


上 面 的 代码 实现 的 是 在 删除 前 先 弹 出 对 话 框 进行 确认 。 对 数据 库 操作 的 代码 如 下 : 


/// «summary» 
/// 删除 相应 记录 
/// </summary> 
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/// «param name= "id"> 按 照 id 查询 要 删除 的 数据 < /param> 

/// <returns> 是 否 删 除 成 功 < /returns> 

public static bool DeleteNews (long id) 

t 
string strConn -ConfigurationManager.ConnectionStrings ["strConn2"].ConnectionString; 
SqlConnection conn - new SqlConnection (strConn); 
conn.Open () ; 


string strSql = "delete from [T News] where id- id"; 
SqlCommand comm =new SqlCommand (strSql, conn); 
comm.Parameters.AddWithValue ("@id", id); 


int i -comm.ExecuteNonQuery () ; 
conn.Close(); 
if (i >0) 


t 
return True; 


return False; 


) 
编辑 页 面 中 进行 删除 处 理 的 代码 如 下 : 


protected void DataListl DeleteCommand(object source, DataListCommandEventArgs e) 
t 
long i -Convert.ToInt64 (DataListl.DataKeys [e.Item.ItemIndex]); 


bool flag —-NewsDB.DeleteNews (i); 

if (flag -- True) 

t 
DataListl.DataSourceID = "ObjectDataSourcel"; 
DataListl.DataBind(); 

else 
this.ClientScript.RegisterStartupScript (this.GetType (), "aa", 


"< script» alert ("删除 不 成 功 !1') ;< /script» "); 
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} 
8.8 小结 


本 章 主要 讲述 一 个 真实 的 项 目的 制作 过 程 。 讲 述 了 单个 表 的 新 闻 发 布 系统 的 实现 方 
式 。 分 别 从 前 台 的 制作 ,到 后 台 的 制作 进行 了 详细 的 讲述 。 
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3593 新 闻 发 布 系统 


本 章 要 点 

。 需求 分 析 。 

。 功能 描述 。 

。 数据 库 说 明 。 

。 项目 界面 展示 。 
。 相应 的 主要 代码 。 


9.1 需求 分 析 


现代 新 闻 学 诞生 有 200 多 年 的 历史 了 ,自从 造纸 术 和 印刷 术 的 出 现 ,新 闻 学 的 发 展 脚步 
就 没有 一 刻 停歇 下 来 , 随 着 技术 的 不 断 进步 ,新闻 也 在 不 断 地 发 生变 化 ,从 早期 的 纸张 记录 ， 
到 蒸汽 印刷 机 带 来 的 报 业 繁 荣 ,乃至 新 闻 电 讯 稿 在 美国 内 战 期 被 广泛 使 用 , 随 着 收音 机 的 兴 
起 ,人 们 听 到 了 更 多 梦 寨 以 求 的 声音 ,电视 台 、 卫 星 电视 的 出 现 , 改 变 了 人 们 的 生活 ,到 了 今 
天 的 网 络 时 代 , 人们 其 至 只 需 一 台 计 算 机 和 一 根 电话 线 就 可 以 看 到 世界 任何 一 处 的 信息 。 
在 不 久 的 未 来 ,相信 手机 将 为 新 闻 带 来 新 的 纪元 。 

网 站 新 闻 发 布 系统 又 称 为 信息 发 布 系统 ,是 将 网 页 上 的 某 些 需 要 经 常 变动 的 信息 ,类 似 
新 闻 ,新 产品 发 布 和 业界 动态 等 更 新 信息 集中 管理 ,并 通过 信息 的 某 些 共 性 进行 分 类 ,最 后 
系统 化 ,标准 化 发 布 到 网 站 上 的 一 种 网 站 应 用 程序 。 网 站 信息 通过 一 个 操作 简单 的 界面 加 
和 数据库 ,然后 通过 已 有 的 网 页 模板 格式 与 审核 流程 发 布 到 网 站 上 。 它 的 出 现 大 大 减轻 了 
网 站 更 新 维护 的 工作 量 , 通 过 网 络 数据 库 的 引用 ,将 网 站 的 更 新 维护 工作 简化 到 只 需 录 入 文 
字 和 上 传 图 片 , 从 而 使 网 站 的 更 新 速度 大 大 缩短 ,在 某 些 专门 的 网 上 新 闻 站 点 ,如 新 浪 的 新 
闻 中 心 等 ,新 闻 的 更 新 速度 已 经 是 即时 更 新 ,从 而 大 大 加 快 了 信息 的 传播 速度 ,也 吸引 了 更 
多 的 长 期 用 户 群 ,时 时 保持 网 站 的 活动 力 和 影响 力 。 

新 闻 发 布 系统 的 主要 功能 为 新 闻 信 息 的 发 布 , 以 及 新 闻 信 息 的 浏览 ,另外 参考 其 他 的 新 
闻 发 布 系统 ,可 以 将 系统 分 为 两 个 部 分 : 一 个 为 后 台 管 理 部 分 ; 另 一 个 为 前 台 显 示 部 分 。 通 
过 后 台 管 理 部 分 来 进行 新 闻 数 据 的 维护 ,通过 前 台 显 示 部 分 进行 新 闻 的 浏览 。 

本 系统 主要 提供 图 片上 传 .浏览 .管理 专辑 等 相关 功能 。 

1. 需求 中 涉及 的 用 户 类 型 

(1) 系统 维护 的 员工 。 

(2) 相关 人 员 。 

(3) 前 台 浏 览 信 息 的 用 户 。 

2. 不 同类 型 用 户 所 进行 的 操作 

CD 系统 维护 的 员工 。 

CD 添加 、 删 除 相关 人 员 。 
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@ 指定 相关 人 员 权 限 。 

C 添加 、 删 除 、 修 改 栏目 。 

© 添加 、 删 除 、 修 改 类 别 。 

© 调整 栏目 .类 别 的 顺序 。 

@ 发 布 新 闻 。 

Q 管理 日 志 。 

@ 分 析 统 计 每 日 .每 月 的 新 闻 信息 。 

@ 修改 密码 。 

(2) 相关 人 员 。 

CD 发 布 新 闻 信 息 。 

@ 分 析 统 计 每 日 .每 月 的 新 闻 信息 。 

@ 修改 密码 。 

(3) 企业 用 户 。 

浏览 新 闻 。 

3. 分 析 结 果 

通过 分 析 上 面 的 需求 ,可 以 得 到 相应 的 角色 的 功能 职责 范围 ,使 用 系统 的 人 可 以 分 为 3 
种 : 第 一 种 为 后 台 部 分 的 系统 管理 员 , 第 二 种 为 后 台 部 分 的 普通 用 户 , 第 三 种 为 前 台 部 分 的 
浏览 器 终端 用 户 。 

各 用 户 角色 及 职责 的 详细 描述 如 表 9. 1 所 示 。 


表 9.1 角色 名 称 及 职责 描述 
角色 名 称 职责 描述 
后 台 系 统管 理 员 用 户 ”| 维护 网 站 信息 ,维护 新 闻 分 类 ,维护 新 闻 ,维护 普通 用 户 基 本 信息 


维护 新 闻 信息 ,查看 当日 新 闻 列表 ,根据 用 户 权限 (用 户 管理 的 新 闻 栏 目 ) 维 护 
栏目 下 的 新 闻 , 包 括 新 闻 信息 的 添加 修改、 删除 .查询 浏览 等 功能 


前 台 浏 览 器 终端 用 户 ”| 浏览 查看 新 闻 


后 台 管理 系统 普通 用 户 


9.2 功能 描述 


9.2.1 后 台 登 录 


新 闻 发 布 系统 要 实现 后 台新 闻 管理 ,栏目 管理 ,用户 管理 等 一 系列 功能 ,而 这 些 功能 的 
实现 之 前 需要 实现 的 是 系统 的 登录 ,新 闻 发 布 系统 要 求 登录 后 台新 闻 管理 的 人 员 有 两 种 : 
一 种 是 普通 后 台 用 户 ; 另 一 种 是 后 台 系 统管 理 员 。 后 台 普 通用 户 可 以 管理 该 用 户 所 管辖 的 
新 闻 分 类 下 的 新 闻 数 据 ,可 以 添加 、 修 改 , 删 除 新 闻 。 并 且 可 以 浏览 当日 所 有 发 布 的 新 闻 ;后 
台 管 理 员 可 以 进行 除 普通 后 台 用 户 的 操作 之 外 ,还 要 能 够 进行 用 户 管理 .栏目 管理 、 类 别管 
理 、 日 志 管理 ,查看 网 站 配置 信息 以 及 新 闻 流 量 月 统计 等 操作 ,登录 系统 时 需要 区 分 这 两 种 
用 户 。 
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9.2.2 ”新闻 栏目 和 类 别管 理 


新 闻 类 别 属于 新 闻 栏 目 ,发 布 新 闻 时 ,选择 新 闻 类 别 即 可 。 栏 目 要 求 能 够 添加 、 删 除 、 修 
改 。 类 别 也 是 同样 的 要 求 ,另外 修改 类 别 时 要 求 能 够 调整 其 所 属 的 栏目 。 新 闻 栏 目 以 及 新 
闻 类 别 显 示 顺 序 要 求 能 够 进行 修改 。 此 功能 由 后 台 管 理 员 进行 操作 ,后 台 普通 用 户 没有 权 
限 操作 。 


9.2.3 用户 管 理 


新 闻 发 布 系统 的 最 终 用 户 划 分 为 三 类 ,专门 负责 系统 维护 的 人 划分 为 后 台 管理 员 ， 
将 发 布 新 闻 信 息 的 用 户 划分 为 后 台 普 通用 户 , 将 公司 员工 及 浏览 网 页 者 定位 为 系统 的 终 
端 用 户 。 

后 台 管 理 员 只 有 一 个 ,初始 化 到 数据 库 中 ,在 系统 中 此 用 户 不 能 被 修改 、 删 除 ,但 是 可 以 
修改 密码 。 后 台 管理 员 可 以 添加 后 台 普 通用 户 , 并 且 可 以 修改 、 删 除 用户, 还 可 以 维护 这 些 
用 户 的 权限 。 后 台 普 通用 户 不 能 添加 后 台 普 通用 户 。 所 有 后 台 用 户 只 允许 修改 自己 的 
密码 。 

后 台 管 理 员 可 以 修改 普通 用 户 的 权限 ,权限 的 形式 为 某 个 后 台 普 通用 户 是 否 拥有 某 个 
新 闻 类 别 的 管理 权 。 系 统 不 为 普通 用 户 设置 栏目 权限 。 后 台 普 通用 户 不 能 修改 权限 。 

终端 用 户 不 需要 添加 到 数据 库 中 ,直接 进行 前 台 页 面 的 浏览 即 可 。 


9.2.4 新 闻 发 布 


要 发 布 的 新 闻 的 内 容 包括 标题 ,所属 类 别 ,发 布 时 间 ,发 布 人, 来源 .关键 字 内容。 其 中 
发 布 时 间 取 服 务 器 当前 时 间 ,发 布 人 取 当 前 登录 用 户 。 其 他 新 闻 项 目 输入 即 可 。 

已 发 布 的 新 闻 能 够 修改 ,已 发 布 的 新 闻 以 列表 形式 显示 (该 列表 要 求 提供 查询 ,能 够 按 
照 类 别 以 及 关键 字 进 行 新 闻 的 查询 ) ,然后 通过 列表 打开 相应 的 新 闻 修 改 页 面 ,保存 数据 时 
发 布 时 间 改 为 当前 的 服务 器 时 间 , 发 布 人 不 再 进行 修改 保持 原 有 数据 即 可 。 其 他 的 新 闻 项 
目 以 修改 后 的 数据 更 新 。 


9.2.5 日 志 管理 ,流量 统计 及 当日 新 闻 查 看 


为 了 系统 的 安全 ,为 了 能 够 了 解 登录 系统 的 都 有 那些 用 户 , 所 以 需要 进行 日 志 的 记录 。 
当 用 户 登 录 系 统 时 需要 记录 下 来 用 户 的 ID ,登录 时 间 以 及 登录 JP, 并 且 可 以 对 这 些 日 志 进 
行 删除 。 

为 了 了 解 当月 最 热点 的 新 闻 , 需 要 有 新 闻 月 流量 的 统计 ,可 以 查看 新 闻 每 月 点 击 率 排 
£r ,排行 榜 按 照 从 多 到 少 的 顺序 排列 。 

发 布 新 闻 时 如 果 其 他 的 用 户 发 布 了 相 类 似 的 新 闻 ,而 当前 登录 用 户 尚 不 了 解 最 新 的 新 
闻 ,这 样 很 容易 造成 新 闻 的 重复 发 布 。 为 了 防止 此 种 情况 ,系统 需要 展示 给 当前 登录 用 户 今 
日 发 布 信息 的 列表 ,以 进行 快速 地 浏览 新 发 布 的 新 闻 信息 。 


9.2.6 前 台 显示 页 面 


前 台 页 面 首页 要 将 所 有 的 栏目 都 显示 出 来 ,并 且 每 个 栏目 下 要 显示 本 栏目 下 最 新 的 10 
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条 新 闻 。 新 闻 列 表 下 要 有 “更 多 …” 的 链接 ,用 于 打开 本 栏目 的 页 面 。 栏 目 页 面包 括 其 下 所 
有 的 类 别 , 类 别 下 同样 显示 本 类 别 下 最 新 的 10 条 新 闻 。 新 闻 列 表 下 也 要 具有 “更 多 …” 的 链 
接 , 用 于 打开 本 类 别 的 页 面 。 类 别 页 面包 括 了 此 类 别 下 的 所 有 新 闻 , 并 且 提 供 分 页 功能 ,新 
闻 以 时 间 倒 序 排序 。 以 上 新 闻 列 表 均 能 单 击 标题 进入 新 闻 浏览 页 面 ,进行 新 闻 的 详细 信息 
的 浏览 。 


9.3 数据库 说明 


首先 新 建 数据 库 News_Manage, 然 后 新 建 系统 用 户 数据 表 t_News_User, 该 表 各 字段 
如 表 9. 2 所 示 。 


表 9.2. t_News_User( 用 户 信息 表 ) 


列 名 描 述 数据 类 型 (精度 范围 ) 空 / 非 空 约束 条 件 
USERID 用 户 ID int 非 空 PK( 自 增 ) 
USERNAME 用 户 名 称 varchar( 50) am 
USERPASSWORD 用 户 密码 varchar(256) a 
POWER 是 否 是 管理 员 bit 空 


t_Item 表 各 字段 如 表 9. 3 所 示 。 
表 9.3 t_Item( 新 闻 栏目 表 ) 


» 名 Wo xk 数据 类 型 (精度 范围 ) 空 / 非 空 约束 条 件 
ITEMID 栏目 ID int 非 空 PK( 自 增 ) 
ITEMNAME 栏目 名 称 varchar(50) 空 
ITEMDESC 栏目 描述 varchar(200) 空 
ITEMORDER 栏目 顺序 int 空 


t Class 表 如 表 9. 4 所 示 。 
表 9.4 t_Class( 新 闻 类 别 表 ) 


» 名 描 — xk 数据 类 型 (精度 范围 ) 空 / 非 空 约束 条 件 
CLASSID 类 别 ID int 非 空 PK( 自 增 ) 
CLASSNAME 类 别名 称 varchar(50) 空 
CLASSDESC 类 别 描述 varchar(200) 空 
CLASSORDER 类 别 顺 序 int 空 
ITEMID 所 属 栏目 ID int 空 
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t Popedom 表 如 表 9. 5 所 示 。 


表 9.5 t Popedom HARER) 

» 名 d xk 数据 类 型 (精度 范围 空 / 非 空 约束 条 件 
POPEDOMID 权限 ID int 非 空 PK( 自 增 ) 
CLASSID 新 闻 类 别 ID int 空 FK 
USERID 用 户 ID int 空 FK 
t News RUIK 9.6 所 示 。 

表 9.6 t_News( 新 闻 表 ) 

列 4 Wo 8 数据 类 型 (精度 范围 ) 空 / 非 空 约束 条 件 
NEWSID 权限 ID int 非 空 PK( 自 增 ) 
NEWSTITLE 新 闻 类 别 ID varchar(100) E 
CLASSID 用 户 ID int 空 FK 
NEWSDATE 发 布 时 间 datetime 空 
NEWSKEY 关键 字 varchar(20) 空 
NEWSOURCE 新 闻 来 源 varchar(100) 空 
NEWSCONTENT 新 闻 内 容 ntext E 
USERID 发 布 人 ID int 空 FK 
HITS 总 点 击 率 int 空 
MONTHHITS 月 点 击 率 int 空 

t Log 表 如 表 9.7 所 示 。 
表 9.7 t Log ES 

» 4 Ho 数据 类 型 (精度 范围 ) 空 / 非 空 约束 条 件 
LOGID 日 志 ID int 空 FK 
LOGINIP 登录 IP varchar(15) 空 
LOGINDATE 登录 时 间 datetime 空 
USERID 用 户 ID int 空 


9.4 相应 的 主要 代码 


9.4.1 


前 台 代码 
本 系统 使 用 的 是 三 层 架 构 来 实现 新 闻 浏 览 的 功能 .前 


A M 4E 


[zo 


分 为 主页 (也 就 是 首页 ) ,分 


类 页 面 (也 就 是 对 于 每 个 分 类 有 更 加 详细 的 显示 ) ,新 闻 显示 页 面 (就 是 当 单 击 某 条 新 闻 时 显 
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示 具 体 新 闻 的 页 面 ) 。 
首页 的 主要 代码 如 下 所 示 ,因为 主页 的 显示 用 的 是 母 版 页 ,关于 母 版 页 的 设计 就 不 一 一 
介绍 了 ,读者 可 以 参考 其 他 书籍 。 


«asp:DataList ID= "dtlIndex" runat="server" DataSourceID- "odsNewsItem" 
RepeatColumns- "3" RepeatDirection- "Horizontal" Width- "672px" 
CellSpacing- "2" ShowFooter- "False" ShowHeader- "False"? 
«EditItemStyle VerticalAlign- "Top" Width- "221px" /> 
< ItemStyle HorizontalAlign- "Left" VerticalAlign- "Top" Width- "220px" /> 
« ItemTemplate» 
«table style- "border: lpx solid £4 CCCCCC; width:100$;" border= "0" 
cellpadding- "0" cellspacing- "0"> 
«tr» 
«td style- "background- color: $& EEEEEE; border-bottom- style: 
solid; border-bottom- width: 1px; border-bottom- color: 
$ CCCCCC;" height- "20"» 
«asp:Image ID- "Imagel" runat="server" ImageUrl- "~ /Images/ 
zl.jpg" /> &nbsp; 
<asp:Label ID- "lblItemName" runat="server" style= 
"font-weight: 700; font-size: small" Text- '« $4 Eval ("ItemName") 
$> '>< /asp:Label> 
<asp:HiddenField ID="hfItemID" runat="server" Value= 
"< $# Eval ("ItemID") $»' /> 
« /td» 
</tr> 
<tr> 
<td Height= "220px" valign="top"> 
<asp:DataList ID="DataList2" runat="server" DataSourceID= 
"odsNews" ShowFooter- "False" ShowHeader- "False" Width= "220px"> 
«EditItemStyle HorizontalAlign- "left" /> 
< ItemStyle HorizontalAlign- "Left" VerticalAlign- "Top" /> 
< ItemTemplate» 
«asp:HyperLink ID- "HyperLinkl" runat="server" NavigateUrl- '«$4Eval 
("NewsID", "NewsView.aspx?NewsID- (0)") %>' Target- " blank" Text- 
'« S4 Eval ("NewsTitle") $> '>< /asp:HyperLink^ 
«br /> 
</ItemTemplate> 
< /asp:DataList» 
< asp:ObjectDataSource ID= "odsNews" 
runat- "server"SelectMethod- "GetIndexList" 
TypeName- "NewsManage . DAL .NewsDB"> 
«SelectParameters» 
«asp:ControlParameter ControlID- "hfltemID" DefaultValue- "$" Name- 
"itemID" PropertyName- "Value" Type- "Int32" /» 


< /SelectParameters^ 
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< /asp:ObjectDataSource» 
</td> 
</tr> 
«tr» 
«td style- "text-align: right" height- "20"> 
«asp:HyperLink ID- "HyperLink?" runat="server" NavigateUrl- 
'« $4 Eval("ItemID", "ItemNews.aspx?ItemID- (0)") $»' Target- 
"self"> 更 多 < /asp:HyperLink» 
«asp:Image ID= "Image?" runat="server" ImageUrl- "- /Images/z7.jpg" /> 
«/td» 
str» 
</table> 
</ItemTemplate> 
< /asp:DataList» 
<asp:ObjectDataSource ID= "odsNewsItem" runat="server" SelectMethod- "GetAll" 
TypeName- "NewsManage . DAL .NewsItemDB"» < /asp:ObjectDataSource> 


最 后 主页 中 使 用 了 ObjectDataSource 控件 ,引用 的 是 类 NewsItemDB 下 的 方法 ,关于 
NewsItemDB 的 具体 代码 如 下 : 


using System.Data.SqlClient; 
using NewsManage.Model; 
namespace NewsManage.DAL 
{ /// < summary» 
// /1temDB 的 摘要 说 明 
/// < /summary> 
public class NewsItemDB 
{ /// < summary» 
/// 得 到 所 有 栏目 
/// < /sumnary» 
/// «xeturns» f: H jÆ < /returns» 
public static IList« NewsItem» GetAll() 
t 
IList«NewsItem» newsItemList —new List« NewsItem» (); 
using ( SqlConnection connection = new SqglConnection ( DBConnection. 
ConnectString)) 
t 
SqlCommand command =new SqlCommand("select * from t Item order by itemorder, 
itemid", connection); 
connection.Open(); 
using (SglDataReader itemReader = command.ExecuteReader ()) 
t 
while (itemReader.Read()) 
t 
NewsItem newsItem =new NewsItem(); 


newsItem —FillData (itemReader); 
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newsItemList.Add (newsItem); 


H 
return newsItemList; 


/// < summary» 
/// 添加 栏目 
/// < /sumnary» 
/// «param name= "itemName"»f* H 44 fk « /param> 
/// «param name- "itemDescription"> 栏 目 描述 < /param> 
/// «param name="itemorder"> 栏 目 顺 序 < /param> 
/// < returns> 是 否 成 功 < /returns» 
public static bool AddItem (string itemName, string itemDescription, int 
itemOrder) 
t 
using (SqlConnection connection = new SqlConnection ( DBConnection. 
ConnectString)) 
t 
SqlCommand command - new SqlCommand ("insert into t item values 
(G&itemname, 6itemdesc, (itemorder)", connection); 
command. Parameters .Add ("8itemname", SqlDbType.VarChar, 50); 
command. Parameters .Add ("@itemdesc", SqlDbType.VarChar, 200); 
command. Parameters .Add ("@itemorder", SqlDbType.Int); 
command. Parameters [0] .Value = itemName; 
command. Parameters [1] .Value = itemDescription; 
command. Parameters [2] .Value —-itemOrder; 
connection.Open(); 


int addItemRows = command.ExecuteNonQuery () ; 
if (addItemRows » 0) 


{ 
return True; 


return False; 


/// «summary» 
/// 删除 栏目 


/// < /summary» 


/// «param name= "itemID"» fH IDK /param» 
public static void DeleteItem(int itemID) 


t 


using (SqlConnection connection = new SqlConnection ( DBConnection. 


Connectstring)) 


i 


SqlCommand commandSelect = new SqlCommand ("select count(* ) from t class 
where itemid- (6itemid", connection); 
SqlCommand commandDelete —new SqlCommand ("delete from t item where itemid 
=@itemid", connection); 
connection.Open(); 
commandSelect.Parameters.Add("Gitemid", Sq1DbType.Int); 
commandSelect.Parameters [0] .Value = itemID; 
commandDelete.Parameters.Add("Gitemid", Sq1DbType.Int); 
commandDelete.Parameters [0] .Value = itemID; 
int classRows -Convert.ToInt32 (commandSelect .ExecuteScalar ()); 
if (classRows » 0) 
{ 
HttpContext.Current.Response.Write("« script» alert (' 该 栏目 
下 有 类 别 数据 ,不 能 删除 ! '); location. replace (window. 
location.href) ;< /script» "); 
} 
else 
{ 
int deleteRows = commandDelete.ExecuteNonQuery () ; 
if (deleteRows » 0) 
t 
/ [BttpContext .Current.. Response. Write ("< script» alert (' 删 除 成 功 !1'); 
location.replace (window.location.href);« /script» "); 
) 
else 
t 
HttpContext . Current. Response. Write ("< script» alert (' 删 
除 失败 ,请 稍 后 重 试 !1') ;location.replace (window. location. 
href) ;< /script> "); 


/// < summary» 


/// 更 新 栏目 信息 


/// < /sumary> 


/// <param name= "itemID'» f: H ID< /param> 
/// <param name= "itemName"» ft H 4% ff « /param> 
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/// «param name= "itemDescription"» ft H Tí 3$ « /param> 
/// «param name= "itemOrder"» fH Ji H* < /param» 
public static void UpdateItem(int itemID, string itemName, string itemDescription, int 
itemOrder) 
t 
using (SqlConnection connection = new SqglConnection ( DBConnection. 
ConnectString)) 
t 
SqiCommand command =new SqlCommand ("update t item set itemname- 
Gitemname,itemdesc- 6itemdescription, itemorder- $itemorder where itemid- 
itemid", connection); 
connection.Open(); 
command. Parameters .Add("Gitemid", Sq1DbType.Int); 
command. Parameters .Add("Gitemname", SqlDbType.VarChar, 50); 
command. Parameters.Add ("Gitemdescription", SqlDbIype.VarChar, 200); 
command. Parameters .Add ("Gitemorder", SqlDbType.Int); 
command. Parameters [0] .Value —- itemID; 
command. Parameters [1].Value = itemName; 
command. Parameters [2].Value —itemDescription; 
command.Parameters[3].Value -itemOrder; 
int updateRows = command.ExecuteNonQuery () ; 
if (updateRows » 0) 
t 
/ /BttpContext. Current . Response. Write ("< script» alert (' 更 新 成 功 !'); 
location.replace (window.location.href);« /script> "); 
} 
else 
£ 
HttpContext Current Response Write ("< script» alert (' 更 新 失败 ,请 稍 后 重 试 1'); 
location.replace (window.location.href);« /script> "); 


private static NewsItem FillData (IDataReader itemReader) 

{ 
NewsItem newsItem =new NewsItem(); 
newsItem. ItemID = itemReader.GetInt32 (itemReader.GetOrdinal ("itemid")); 
newsItem. ItemName —itemReader.GetString (itemReader.GetOrdinal 
("itemname")); 
newsItem.ItemDescription = itemReader.GetString (itemReader.GetOrdinal 
("itemdesc")); 
newsItem.ItemOrder = itemReader .GetInt32 (itemReader.GetOrdinal 
("itemorder")); 


return newsItem; 
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} 


上 面 是 首页 的 主要 代码 ,下 面 把 如 何 显示 具体 新 闻 的 代码 列 出 ,其 他 页 的 内 容 根据 这 两 
个 页 的 提示 ,读者 自己 查阅 源 代码 。 显 示 新 闻 的 页 面 代码 如 下 : 


«table style= "width:100$;"» 
«tr» 
«td colspan- "3" style- "text- align: center"» 
<asp:Label ID-"lblNewsTitle" runat="server" SkinID- "NewsTitle"» 


« /asp:Label» 
« /td» 
</tr> 
Str» 


<td colspan- "3" style- "text-align: center"» 
«hr size-"1" style="height: - 13px" /> 
« /td» 
</tr> 
<tr> 
«td style= "text- align: center" width- "33$" class="style3"> 
< span class =" stylel"> 所 届 栏 目 : </span> < asp: Label ID=" 
lblItemName" runat- "server" SkinID- "NewsInfo" style=" font- size: 
12px"» < /asp: Label» 
</td> 
«td style="text-align: center" width= "33$" class= "style3"» 
< span class- "stylel"> 所 属 类 别 : </span> <asp:Label ID- "lblClassName" runat=" 
server" SkinID- "NewsInfo"»« /asp:Label» 
</td> 
«td style="text-align: center" title- "34$" class="style3"> 
«span class="stylel"> 发 布 时 间 : « /span» « asp: Label ID- "lblNewsDate" runat- " 
server" SkinID- "NewsInfo"»« /asp:Label» 
</td> 
</tr> 
<tr> 
<td colspan= "3" style="text-align: center" width= "33$" class= "style2"» 
<span class="stylel"> 搜 索 关 键 字 : </span> <asp:Label ID-"lblKeywords" runat=" 
server" SkinID- "NewsInfo">< /asp:Label> 
&nbsp;&nbsp;&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; < span 
class- "stylel"> 新 闻 来 源 : < /span» « asp:Label ID= 
"lblNewsSource" 
runat="server" SkinID- "NewsInfo"»« /asp:Label» 
<hr size-"1" style="height: - 13px" /> 
«/td» 
«/tr» 
«tr» 
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«td colspan- "3" style- "text-align: left"» 
<asp:Label ID-"lblContent" runat- "server" Width- "100%">< /asp:Label» 
«/td» 
</tr> 
<tr> 
«td colspan- "3" style="text-align: right" class= "style2"> 
<span class="stylel"> 新 闻 作 者 : </span> <asp:Label ID-"lblUserName" runat-" 
server" SkinID- "NewsInfo">< /asp:Label» 
«/td» 
«/tr» 
</table> 


这 一 页 的 . cs 文件 中 的 代码 如 下 : 


using NewsManage.DAL; 
using NewsManage.Model; 


public partial class NewsView : System.Web.UI.Page 
t 
protected void Page Load(object sender, EventArgs e) 
t 
News news =new News () ; 
if (Request.QueryString["NewsID"] !-null) 
t 
news —NewsDB.GetSingle (Convert .ToInt32 (Request .QueryString 
["NewsID"].ToString())); 
if (NewsDB.UpdateHits (news.NewsID)) 
t 
lblNewsTitle.Text —news.NewsTitle; 
lblItemName.Text —news.ItemName; 
lblClassName.Text —news.ClassName; 
lblNewsDate.Text —news.NewsDate.ToString ("yyyy ^F M H aa H "); 
lblKeywords.Text —news.NewsKeywords; 
lblNewsSource.Text - news.NewsSource; 
lblContent.Text —-HttpUtility.HtmlDecode (news .NewsContent) ; 
lblUserName.Text — news .UserName; 


this.Title -news.NewsTitle; 
else 
Page.RegisterStartupScript ("errl", "< script» alert ('1] JF 39i W Ac We! '); 


window.opener- 'anyone';window.close();« /script» "); 


else 
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Page.RegisterStartupScript ("errl", "«script»alert (S BURBEIZ: 1); 


window.opener- 'anyone';window.close();« /script» "); 


) 

代码 的 最 开头 进入 了 两 个 命名 空间 ,这 两 个 命名 空间 是 在 建立 类 的 时 候 自 己 起 的 命名 
空间 ,因为 在 这 个 页 面 中 要 用 到 类 中 的 方法 ,所 以 要 把 命名 空间 首先 添加 进来 。 这 个 页 中 引 
用 到 NewsDB 这 个 类 ,下 面 把 这 个 类 中 的 定义 显示 如 下 : 


using System.Data.SqlClient; 
using NewsManage.Model; 
namespace NewsManage .DAL 
{ /// «summary» 
/// 添加 新 闻 
/// < /summary> 
/// «param name= "newsTitle"> 新 闻 标 题 < /param> 
/// «param name= "classID"> 所 属 类 别 ID< /param> 
/// «param name= "newsDate"» 发 布 时 间 < /param> 
/// «param name- "newsKeywords"> 关 键 字 < /param> 
/// «param name- "newsSource"> 新 闻 来 源 < /param> 
/// «param name= "newsContent"> 新 闻 内 容 < /param> 
/// «param name= "userID"> 发布 人 ID< /param> 
/// <returns>< /returns> 
public static bool AddNews (string newsTitle,int classID,DateTime newsDate, 
string newsKeywords, string newsSource, string newsContent, int userID) 
t 
using (SqlConnection connection —new SqlConnection (DBConnection.ConnectString)) 
t 
SqlCommand command =new SqlCommand ("insert into t news values 
(Gnewstitle,6classid, @newsdate, @newskey, 6énewssource, 6Ánewscontent, 
@userid, 0,0)", connection); 
command.Parameters .AddWithValue ("newstitle", newsTitle); 
command. Parameters .AddWithValue ("classid", classID); 
command. Parameters.AddWithValue ("newsdate", newsDate); 
command. Parameters .AddWithValue ("newskey", newsKeywords); 
command. Parameters.AddWithValue ("newssource", newsSource); 
command. Parameters .AddWithValue ("newscontent", newsContent); 
command. Parameters.AddWithValue ("userid", userID); 
connection.Open(); 
int insertRows = coammand.ExecuteNonQuery () ; 
if (insertRows >0) 
t 


return True; 


else 
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return False; 


H 
/// «sumnary» 
/// 删除 新 闻 
/// </summary> 
/// «param name= "newsID"> 新 闻 ID« /param> 
public static void DeleteNews (int newsID) 
t 
using (SqlConnection connection —new SqlConnection (DBConnection.ConnectString)) 
f 
SqlCormand command - new SglConmand ("delete from t news where newsid- 
Gnewsid", connection); 
command. Parameters .AddWithValue ("newsID", newsID); 
connection.Open () ; 
command.ExecuteNonQuery () ; 


H 
/// «summary» 
/// 得 到 新 闻 列表 
/// </summary> 
/// «param name= "classID"> 类 别 ID< /param> 
/// «param name= "newsKeywords"> 关 键 字 < /param» 
/// <returns> 新 闻 列 表 < /returns> 
public static IList<News> GetList (string classID, string newsKeywords) 
t 
string getNewsList; 
Administrator admin = (Administrator)HttpContext.Current.Session 
["CurrentUser"]; 
if (admin.Power) 
t 
getNewsList — "select a.newsid,a.newstitle, isnull(a.newsource, 
'&nbsp;') as newsource, isnull (a.newskey, '&nbsp; ') as newskey, 
a.userid,a.hits,a.monthhits,a.classid,a.newsdate,isnull 
(a.newscontent, '') as newscontent,b.itemid,b.itemname,c.classname, 
d.username from t news a,t item b,t class c,t news user d where 
a.classid-c.classid and b.itemid- c.itemid and a.userid-d.userid and 
a.classid like (classid and isnull (a.newskey,'') like 6newsKeywords 
order by newsdate desc,newsid desc"; 


getNewsList — "select a.newsid,a.newstitle,isnull (a.newsource, 


) 


) 


'&nbsp; ') as newsource, isnull (a.newskey, ' &nbsp; ') as newskey, 
a.userid,a.hits,a.monthhits,a.classid,a.newsdate,isnull 
(a.newscontent, '') as newscontent,b.itemid,b.itemname,c.classname, 
d.username from t news a, t item b,t class c,t news user d where 
a.classid-c.classid and b.itemid- c.itemid and a.userid-d.userid and 
a.classid like 6classid and isnull(a.newskey,'') like GnewsKeywords 
and a.classid in(select classid from t popedom where userid- "4 


admin.UserID.ToString()-*") order by newsdate desc, newsid desc"; 


IList«News» newsList =new List< News> (); 
using (SqlConnection connection =new SqlConnection (DBConnection.ConnectString)) 


t 


connection.Open () ; 
SqiCommand command =new SqlCommand (getNewsList, connection); 
command. Parameters .AddWithValue ("@classid", classID); 
comand. Parameters Addi thiValue ("GnewsKeywords", "$" -newsKeywords 4-"$") ; 
using (SqlDataReader newsReader = command.ExecuteReader () ) 
t 
while (newsReader.Read()) 
t 
News news —new News () ; 
news =FillData (newsReader); 


newsList.Add (news); 


) 
return newsList; 


/// < summary» 

/// 得 到 当日 新 闻 列 表 

///</summary> 

/// <returns> 新 闻 列 表 < /returns> 

public static IList<News> GetTodayList () 


t 


string getNewsList; 


getNewsList — "select a.newsid,a.newstitle,isnull (a.newsource, '&nbsp; ') 


as newsource, isnull (a.newskey, '&nbsp;') as newskey,a.userid,a.hits, 


a.monthhits,a.classid,a.newsdate, isnull (a.newscontent, '') as newscontent, 


b.itemid,b.itemname,c.classname,d.username from t news a,t itemb, 


t class c,t news user d where a.classid- c.classid and b.itemid- c.itemid 
and a.userid-d.userid and a.newsdate between CONVERT (varchar, getdate (), 
111) and CONVERT (varchar, getdate ()-1,111) order by newsdate desc,newsid desc"; 
IList« News» newsList —new List« News» (); 

using (SqlConnection connection —new SqlConnection (FBConnection.ConnectString)) 

{ 
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) 


connection.Open(); 
SqlCommand command =new SqlCommand (getNewsList, connection); 
using (SglDataReader newsReader = command.ExecuteReader ()) 
Li 
while (newsReader.Read()) 
{ 
News news =new News (); 
news =FillData (newsReader); 
newsList.Add (news) ; 


) 
return newsList; 


/// «summary» 

/// 得 到 月 流量 统计 列表 

/// </summary> 

/// <returns> 新 闻 列 表 < /returns> 

public static IList<News> GetMonthNews () 


{ 


string getNewsList; 
getNewsList - "select a.newsid,case when len (a.newstitle)» 15 then left 
(a.newstitle,15)- '… ' else a.newstitle end as newstitle,isnull (a.newscurce, 
'&nbsp; ') as newsource, isnull (a.newskey, '&nbsp; ') as newskey,a.userid, 
a.hits,a.monthhits,a.classid,a.newsdate, isnull (a.newscontent, '') as 
newscontent,b.itemid,b.itemname,c.classname,d.username from t news a, 
t itemb,t class c,t news user d where a.classid-c.classid and b.itemid- 
c.itemid and a.userid-d.userid order by monthhits desc,newsid desc"; 
IList« News» newsList =new List« News» (); 
using (SqlConnection connection —new SqlConnection (DBConnection.ConnectString)) 
t 
connection.Open () 7 
SqlCommand command — new SqlCommand (getNewsList, connection); 
using (SqlDataReader newsReader = command.ExecuteReader () ) 
t 
while (newsReader.Read()) 
t 
News news =new News () 7 
news —FillData (newsReader); 
newsList .Add (news) ; 


} 


return newsList; 


/// «summary» 
/// 得 到 首页 新 闻 列 表 
/// </summary> 
/// «param name- "itemID"> 新 闻 栏 目 ID< /param> 
/// <returns> 新 闻 列 表 < /returns> 
public static IList<News> GetIndexList (int itemID) 
{ 
string getNewsList; 
getNewsList ="select top 10 a.newsid, case when len (a.newstitle)>15 then 
left (a.newstitle,15)+ "+ ' else a.newstitle end as newstitle,isnull 
(a.newsource, '&nbsp; ') as newsource, isnull (a.newskey, '&nbsp; ') as newskey, 
a.userid,a.hits, a.monthhits, a.classid,a.newsdate, isnull (a.newscontent, ' ') 
as newscontent,b.itemid,b.itemname, c.classname,d.username from t news a, 
t itemb,t class c,t news user d where a.classid-c.classid and b.itemid- 
c.itemid and a.userid-d.userid and b.itemid- 6itemid order by newsdate 
desc,newsid desc"; 
IList«News» newsList —new List« News» (); 
using (SqlConnection connection =new SqiConnection (DBConnection.ConnectString)) 
{ 
connection.Open (); 
SqlCommand command =new SqlCommand (getNewsList, connection); 
command. Parameters .AddWithValue ("@itemid", itemID); 
using (SqlDataReader newsReader = command.ExecuteReader () ) 
t 
while (newsReader.Read()) 
t 
News news —new News () ; 
news —FillData (newsReader); 
newsList.Add (news); 


) 
return newsList; 

} 

/// < summary» 

/// 得 到 栏目 页 新 闻 列 表 

/// </summary> 

/// «param name- "itemID"> 新 闻 栏 目 ID< /param> 

/// <returns> 新 闻 列 表 < /returns> 

public static IList<News> GetItemList (int classID) 

t 
string getNewsList; 
getNewsList — "select top 10 a.newsid,case when len (a.newstitle)» 15 then 
left (a.newstitle,15)- '--* ' else a.newstitle end as newstitle,isnull 
(a.newsource, '&nbsp;') as newsource, isnull (a.newskey, '&nbsp;') as newskey, 
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a.userid,a.hits,a.monthhits, a.classid,a.newsdate, isnull (a. newscontent, ' ') 
as newscontent,b.itemid,b.itemname,c.classname,d.username from t news 
a,t itemb,t class c,t news user d where a.classid-c.classid and b.itemid- 
c.itemid and a.userid-d.userid and a.classid- 6classid order by newsdate desc,newsid 
desc"; 
IList< News> newsList =new List< News> (); 
using (SqlConnection connection —new SqlConnection (PBConnection.ConnectString)) 
t 
connection.Open(); 
SqlCommand command —new SqlCommand (getNewsList, connection); 
command. Parameters .AddWithValue ("@classid", classID); 
command. Parameters [0] .Value —- classID; 
using (SqlDataReader newsReader - command.ExecuteReader () ) 
t 
while (newsReader.Read()) 
t 
News news —new News () ; 
news —FillData (newsReader); 
newsList.Add (news) ; 


) 
return newsList; 
} 
/// < summary> 
/// 得 到 类 别 页 新 闻 列表 
/// < /summary» 
/// «param name= "itemID"> 新 闻 栏 目 ID< /param» 
/// <returns> 新 闻 列 表 < /returns> 
public static IList<News> GetClassList(int classID) 
{ 
string getNewsList; 
getNewsList — "select a.newsid,a.newstitle, isnull (a.newsource, '&nbsp; ') 
as newsource, isnull (a.newskey, '&nbsp;') as newskey,a.userid,a.hits, 
a.monthhits,a.classid,a.newsdate, isnull (a.newscontent, '') as newscontent, 
b.itemid,b.itemname,c.classname,d.username from t news a,t itemb, 
t class c,t news user d where a.classid- c.classid and b.itemid- c.itemid 
and a.userid-d.userid and a.classid- 6classid order by newsdate desc, 
newsid desc"; 
IList« News» newsList —new List« News» (); 
using (SqlConnection connection —new SqlConnection (FBConnection.ConnectString)) 
t 
connection.Open(); 
SqlCommand command = new SqlCommand (getNewsList, connection); 
command. Parameters .AddWithValue ("(classid", classID); 
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using (SqlDataReader newsReader = command.ExecuteReader ()) 
{ 
while (newsReader.Read()) 
1 
News news —new News () 7 
news —FillData (newsReader); 
newsList.Add (news); 


} 
return newsList; 
i 
/// «summary» 
/// 得 到 单条 新 闻 数 据 
/// </summary> 
/// «param name= "newsID"> 新 闻 ID« /param> 
/// <returns> 新 闻 对 象 < /returns» 
public static News GetSingle (int newsID) 
t 
News news -new News () ; 
string getNews; 
getNews = "select a.newsid,a.newstitle, isnull (a.newsource, '&nbsp; ') 
as newsource, isnull(a.newskey, '&nbsp; ') as newskey, a.userid,a.hits, 
a.monthhits,a.classid,a.newsdate, isnull (a.newscontent, '') as newscontent, 
b.itemid,b.itemname,c.classname,d.username from t news a,t itemb, 
t class c,t news user d where a.classid-c.classid and b.itemid-c.itemid 
and a.userid-d.userid and a.newsid- 6newsid order by newsdate desc,newsid desc"; 
using ( SqlConnection connection = new  SqlConnection ( DBConnection. 
ConnectString)) 
{ 
connection.Open () ; 
SqlCommand command - new SqlCommand (getNews, connection); 
command. Parameters .AddWithValue ("énewsid", newsID); 
using (SqlDataReader newsReader = command.ExecuteReader () ) 
t 
while (newsReader.Read()) 


t 
news —FillData (newsReader); 


} 
return news; 
i 
/// «summary» 
/// 更 新 新 闻 
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/// « /summary» 
/// «param name- "newsTitle"> 新 闻 标 题 < /param> 
/// «param name= "classID"> 类 别 ID< /param» 
/// «param name= "newsDate"> 更 新 时 间 < /param> 
/// <param name "newsKeywords"> 关 键 字 < /param> 
/// «param name= "newsSource"> 新 闻 来 源 < /param> 
/// «param name- "newsContent"> 新 闻 内 容 < /param> 
/// <returns> 是 否 成 功 < /returns» 
public static bool UpdateNews ( string newsTitle, int classID, DateTime 
newsDate, string newsKeywords, string newsSource, string newsContent, int 
newsID) 
t 
using ( SqlConnection connection = new SqlConnection ( DBConnection. 
ConnectString)) 
t 
connection.Open() ; 
SqlCommand command = new SqlCommand ("update t news set newstitle- @ 
newstitle, classid- 6 classid, newsdate- @ newsdate, newskey- @ newskey, 
newsource- @ newsource, newscontent- @ newscontent where newsid- @ 
newsid", connection); 
command. Parameters .AddWithValue ("Gnewstitle", newsTitle); 
command. Parameters .AddWithValue ("@classid", classID); 
command. Parameters .AddWi thValue ("@newsdate", newsDate); 
command. Parameters .AddWithValue ("Gnewskey", newsKeywords); 
command. Parameters .AddWi thValue ("$newsource", newsSource); 
command. Parameters .AddWi thValue ("$newscontent", newsContent); 
command. Parameters .AddWithValue ("&newsid", newsID); 
int updateRows —command.ExecuteNonQuery () ; 
if (updateRows » 0) 
t 
return True; 


return False; 


) 

/// «summary» 

/// 更 新 文章 点 击 率 

/// </summary> 

/// «param name= "newsID"> 新 闻 ID< /param> 
/// <returns> 是 否 成 功 < /returns> 

public static bool UpdateHits (int newsID) 


using (SglConnection connection =new SqlConnection (DBConnection.ConnectsString)) 
{ 

SqlCommand command =new SqlCommand ("update t news set hits=hits+1,monthhits= 

monthhits- 1 where newsid- (newsid", connection); 

command. Parameters .Add ("@newsid", SqlDbType.Int); 

command.Parameters [0] .Value —-newsID; 

connection.Open(); 

int updateRows — command. ExecuteNonQuery () ; 

if (updateRows >0) 

t 

return True; 


return False; 


) 

/// < summary» 

/// 填充 对 象 数据 

/// « /summary» 

/// «param name= "newsReader"» jj |] Reader« /param» 

/// «returns» « /returns» 

private static News FillData (IDataReader newsReader) 

t 
News news —new News () ; 
news.NewsID —newsReader.GetInt32 (newsReader.GetOrdinal ("newsid")); 
news.NewsTitle —newsReader.GetString (newsReader.GetOrdinal ("newstitle")); 
news.ClassID - newsReader.GetInt32 (newsReader .GetOrdinal ("classid")); 
news.ClassName —newsReader.GetString (newsReader.GetOrdinal ("classname")) ; 
news.ItemID —newsReader.GetInt32 (newsReader.GetOrdinal ("itemid")); 
news. ItemName — newsReader.GetString (newsReader.GetOrdinal ("itemname") ) ; 
news.NewsDate — newsReader.GetDateTime (newsReader .GetOrdinal ("newsdate") ) ; 
news.NewsKeywords —newsReader.GetString (newsReader .GetOrdinal ("newskey") ) ; 
news.NewsSource —newsReader.GetString (newsReader.GetOrdinal ("newsource")) ; 
news.NewsContent —newsReader.GetString (newsReader.GetOrdinal ("newscontent") ) ; 
news.UserID -newsReader.GetInt32 (newsReader.GetOrdinal ("userid")); 
news.UserName = newsReader.GetString (newsReader.GetOrdinal ("username") ) ; 
news.Hits —newsReader.GetInt32 (newsReader.GetOrdinal ("hits")); 
news.MonthHits —newsReader.GetInt32 (newsReader.GetOrdinal ("monthhits")); 
return news; 


} 
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9.4.2 后 台 代 码 


后 台 的 代码 主要 是 对 数据 库 中 每 个 表 的 添加 、 删 除 .修改 等 操作 。 也 就 是 对 新 闻 的 添加 
编辑 ,对 栏目 的 添加 编辑 ,对 分 类 的 添加 编辑 ,再 就 是 对 于 用 户 权限 的 设置 。 
下 面 的 代码 显示 了 如 何 添加 新 闻 和 如 何 编辑 新 闻 。 


< form id- "forml" runat="server"> 
<table style="width: 900px; "> 
<tr> 
<td class= "stylel"» &nbsp;« /td» 
«td» 
«table style- "border: lpx solid 4 COCOCO; width:100$;" border- "1" 
cellpadding- "1" cellspacing- "0" > 
«tr» 
«td class- "style3"> 新 闻 标 题 : < /td> 
«td class= "style2"> 
<asp:TextBox ID= "txtNewsTitle" runat="server" Width- "400px"» « / 


asp:TextBox^ 

«asp: RequiredFieldValidator ID-"rfvNewsTitle" runat- "server" 
ControlToValidate =" txtNewsTitle " Display = "Dynamic" 
ErrorMessage =" 新 W $5 Ji AR E Jg 4!" > </asp: 
RequiredFieldValidator» 


«asp:RegularExpressionValidator ID= "revNewsTitle" runat 
=" server" ControlToValidate =" txtNewsTitle" Display-" 
Dynamic" ErrorMessage =" 禁止 输入 非法 字符 ! 
ValidationExpression- "[^$&amp; ', ;=?$ Vx22] +">< /asp: 
RegularExpressionValidator» 
</td> 
</tr> 
<tr> 
<td class= "style4"> 所 属 类 别 : < /td> 
<td> 
«asp:DropDownList ID- "dddlNewsClass" runat- "server" style-" 
font-size: 12px" AppendDataBoundItems- "True"> 
<asp:ListItem Value= "None">= 请 选择 所 属 类 别 =< /asp: ListItem 
> 
< /asp:DropDownList» 
«asp: RequiredFieldValidator ID="rfvNewsClass" runat- "server" 


ControlToValidate =" dddlNewsClass " Display = "Dynamic" 
ErrorMessage=" 新 闻 类 别 不 能 为 空 !" InitialValue- "None"» < /asp: 
RequiredFieldValidator> 
«/td» 
</tr> 
«tr» 


«td class- "style4"> 发 布 时 间 : </td> 
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«td» 
<asp:Label ID- "lblPublishDate" runat="server"> 


< /asp:Label» 
«/td» 
</tr> 
<te> 
<td class= "style4"» X BEY : </td> 
«td» 
<asp:TextBox ID-"txtKeywords" runat="server" Width- "200px"» < / 
asp:TextBox^ 
< asp: RegularExpressionValidator ID- "revKeywords" runat 
=" server" ControlToValidate =" txtKeywords" Display =" 
Dynamic" ErrorMessage =" 禁 止 输入 非法 字符 !" 
ValidationExpression- "[^$&amp; ', ;=?$ \x22] +"> < /asp: 
RegularExpressionValidator> 
</td> 
</tr> 
«tr» 
«td class- "style4"> 新 闻 来 源 : < /td> 
<td> 
<asp:TextBox ID= "txtNewsFrom" runat="server" Width- "200px"» 
< /asp:TextBox» 
< asp: RegularExpressionValidator ID=" revNewsFrom" runat 
=" server" ControlToValidate =" txtNewsFrom" Display =" 
Dynamic" ErrorMessage =" 禁止 输入 非法 字符 ! 
ValidationExpression- "[^$&amp; ', ;=?$ \x22] +">< /asp: 
RegularExpressionValidator> 
</td> 
</tr> 
<tr> 
«td class="style4"> 新 闻 内 容 : </td> 
«td» 
< FCKeditorV2: FCKeditor ID=" fckNewContent" runat- "server" 
BasePath- "FCKeditor/" Height- "350px" Width- "99$" ToolbarSet- " 
Medium"> < /FCKeditorV2:FCKeditor» 
< asp: CustomValidator ID =" cvNewsContent" runat = 
"server" ErrorMessage =" 新 闻 内 容 不 能 为 空 !" 
ClientValidation-Function =" CustomValidate " 
ControlToValidate- "fckNew Content" Display- " Dynamic" 
ValidateEmptyText= "True"> < /asp:CustomValidator> 
«/td» 
«/tr» 
«tr» 
«td class- "style4"» &nbsp;« /td» 
«td» 
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«asp:Button ID- "btnSave" runat- "server" Text- " 保 1f " onclick 
—"ptnSave Click" /> 

&nbsp; &nbsp;« input id- "btnReset" type- "Reset" value- "i Hp" /> 

«/td» 
«/tr» 
</table> 
« /td» 
</tr> 
</table> 
< /form» 


对 应 的 . cs 文件 如 下 : 


using NewsManage.Model; 
using NewsManage.DAL; 
public partial class Admin AddNews : System.Web.UI.Page 
t 
Administrator admin =new Administrator (); 
protected void Page Load(object sender, EventArgs e) 
t 
if (Session["CurrentUser"] -- null) 
t 
Page.RegisterStartupScript ("errl", "< script» parent.window.opener- 'anyone';window. 
open ('Loggin.aspx') ;parent .window.close () ;« /script» ") ; 
) 
else 
t 
admin = (Administrator) Session ["CurrentUser"]; 
lblPublishDate.Text = string. Format ("(0:yyyy 年 MI 月 dd H }", DateTime. 
Today) ; 
if (!IsPostBack) 
t 
dddlNewsClass.DataTextField = "ClassName"; 
dddlNewsClass.DataValueField = "ClassID"; 
if (admin.Power) 
{ 
IList<NewsClass> newsClassListAll =new List< NewsClass> (); 
newsClassListAll -NewsClassDB.GetAll(); 
dddlNewsClass.DataSource -newsClasslistAll; 
dddlNewsClass.DataBind(); 


else 


IList«NewsClass» newsClassList =new List« NewsClass» (); 
newsClassList -NewsClassDB.GetListByUser (admin.UserID); 
dddlNewsClass.DataSource -newsClassList; 
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} 


dddlNewsClass.DataBind(); 


protected void btnSave Click (object sender, EventArgs e) 


i 


string newsTitle,newsKeywords,newsSource, newsContent; 
newsTitle -txtNewsTitle.Text; 
if (txtKeywords.Text.Trim() !-"") 
t 
newsKeywords —txtKeywords.Text.Trim(); 
) 
else 
t 
newsKeywords = "&nbsp;"; 
) 
if (txtNewsFrom.Text.Trim() !-"") 
t 
newsSource -txtNewsFrom.Text.Trim(); 
) 
else 
t 
newsSource - "&nbsp;"; 
) 
newsContent —-HttpUtility.HtmlEncode (fckNewContent Value); 


if ( NewsDB. AddNews ( newsTitle, Convert. ToInt32 ( dddlNewsClass. 
SelectedValue), DateTime. Today, newsKeywords, newsSource, newsContent, 
admin.UserID)) 
t 
txtNewsTitle.Text = 
txtKeywords.Text — 
txtNewsFrom.Text —""; 
fckNewContent.Value =""; 
Page.RegisterStartupScript ("okl", "< script» alert (' 添 加 新 闻 成 功 !');</script 


else 


Page.RegisterStartupScript ("errl", "< script» alert ("添加 失败 ,请 稍 后 重 试 !1')</ 
script>"); 
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对 于 新 闻 的 编辑 如 何 实现 ,代码 如 下 : 


< form id- "forml" runat="server"> 
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«table style= "width: 790px;"» 
«tr» 


</tr> 
<tr> 


«td» 
&nbsp; gnbsp; 检 索 关键 字 : <asp:TextBox ID= "txtNewsKeywords" runat- 
"server" Width- "230px"» « /asp: TextBox» 
&nbsp; gnbsp;< asp: DropDownList ID- "dddlNewsClass" runat- "server" 
AppendDataBoundItems- "True" style="font- size: l2px"» 
<asp:ListItem Value= "%">= 请 选择 新 闻 类 别 =< /asp:ListItem» 
</asp:DropDownList> 
&nbsp; &nbsp;« asp:Button ID= "btnRetrieve" runat="server" Text- 
"检索 新 闻 " /> 

</td> 

<td> 


<asp:GridView ID= "gdvNews" runat= "server" BackColor- "White" 
BorderColor- "4 3366CC" BorderStyle- "None" BorderWidth- "lpx" 
CellPadding-" 
DataSourceID- "odsNews" AllowPaging- "True" AutoGenerateColumns- 
"False" PageSize- "15" Width- "780px" ondatabound- "gdvNews DataBound" 
DataKeyNames- "NewsID"> 
< PagerSettings FirstPageText- "首页 " LastPageText- "X Ji " Mode- 
"NumericFirstLast" NextPageText- " | — J" PreviousPageText- "上 一 页 "” /> 
« FooterStyle BackColor- "4 99CCCC" ForeColor- "# 003399" /> 
«RowStyle BackColor- "White" ForeColor- "4 003399" /> 
«Columns» 
«asp:BoundField DataField- "NewsID" HeaderText- "编号 " 
SortExpression- "NewsID"» 
< ItemStyle Width- "50px" /> 
< /asp:BoundField» 
«asp:BoundField DataField- "NewsTitle" HeaderText- "新 闻 标 题 " 
SortExpression- "NewsTitle"> 
<Itemstyle Width- "280px" /> 
</asp:BoundField> 
<asp:BoundField DataField- "ClassName" HeaderText- "所 属 类 别 " 
SortExpression- "ClassName"» 
< ItemStyle Width- "100px" /> 
< /asp:BoundField» 
«asp:BoundField DataField- "NewsDate" DataFormatString- 
"(O:yyyy- MM- add)" 
HeaderText- "发 布 时 间 " SortExpression- "NewsDate"» 
«ItemStyle Width- "80px" /> 
< /asp:BoundField» 


«asp:BoundField DataField- "NewsSource" HeaderText- "新 闻 来 源 " 
SortExpression- "NewsSource" HtmlEncode- "False"> 
«ItemStyle Width- "l00px" /> 
< /asp:BoundField» 
« asp:BoundField DataField- "Hits" HeaderText- "点 击 " 
SortExpression- "Hits"» 
«ItemStyle Width- "50px" /> 
< /asp:BoundField» 
«asp:HyperLinkField DataNavigateUrlFields- "newsid" 
DataNavigateUrlFormatString- "EditNews.aspx?NewsID- {0}" 
HeaderText- "编辑 " 
Text= "编辑 "> 
<Itemstyle Width= "30px" /> 
< /asp:HyperLinkField> 
<asp:TemplateField HeaderText= "删除 " ShowHeader- "False" 
< ItemTemplate» 
< asp: LinkButton ID=" lbDelete" runat-" server" Causes- 
Validation- "False" CommandName- "Delete" Text- "删除 "> < / 
asp: LinkButton» 
« /ItemTemplate» 
« ItemStyle Width- "30px" /» 
< /asp: TemplateField» 
< /Columns» 
< PagerStyle BackColor- "# CCCCCC" ForeColor- "# 003399" HorizontalAlign 


- "Right" /> 

< SelectedRowStyle BackColor- "4 009999" Font- Bold- "True" ForeColor- "4 CCFF99" / 
2 

< HeaderStyle BackColor-" # 003399" Font- Bold-" True" ForeColor-" # 
CCCCFF" /> 


< /asp:GridView» 
«asp:ObjectDataSource ID- "odsNews" runat="server" SelectMethod- 
"GetList" TypeName- "NewsManage.DAL.NewsDB" DeleteMethod- "DeleteNews"? 
«SelectParameters» 
< asp: ControlParameter ControlID-" dddlNewsClass" DefaultValue -"$" Name-" 
classID" PropertyName- "SelectedValue" Type- "String" /> 
«asp:ControlParameter ControlID- "txtNewsKeywords" DefaultValue- 
"$" Name- "newsKeywords" PropertyName- "Text" Type- "String" /» 
< /SelectParameters^ 
< /asp:O0bjectDataSource» 
</td> 
«/tr» 
</table> 
<br /> 
<asp:HyperLink ID="hlAddNews" runat="server" NavigateUrl="~ /Admin/AddNews.aspx"> 添 加 新 
IH] < /asp:HyperLink» 
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< /form» 
对 应 的 . cs 文件 如 下 : 


using NewsManage.DAL; 
using NewsManage.Model; 
public partial class Admin ManageNews : System.Web.UI.Page 
t 
Administrator admin =new Administrator (); 
protected void Page Load(object sender, EventArgs e) 
t 
if (Session["CurrentUser"] -- null) 
t 
Page.RegisterStartupScript ("errl", "< script» parent.window.opener- 
'anyone' ;window.open ('Loggin.aspx') ;parent .window.close () ;« /script» ") ; 
) 
else 
t 
admin = (Administrator)Session["CurrentUser"]; 
if (!IsPostBack) 
t 
dddlNewsClass.DataTextField = "ClassName"; 
dddlNewsClass.DataValueField = "ClassID"; 
if (admin.Power) 
t 
IList«NewsClass» newsClassListAll =new List«NewsClass» (); 
newsClassListAll —NewsClassDB.GetAll(); 
dddlNewsClass.DataSource -newsClassListAll; 
dddlNewsClass.DataBind(); 


else 


IList«NewsClass» newsClassList =new List«NewsClass» (); 
newsClassList —NewsClassDB.GetListByUser (admin.UserID); 
dddlNewsClass.DataSource - newsClassList; 
dddlNewsClass.DataBind(); 


} 
protected void gdvNews_DataBound (object sender, EventArgs e) 
f 
for (int i =0; i <gdvNews.Rows.Count; i++) 
í 
gdvNews .Rows [i] .Attributes.Add ("onmouseover", "c= this.style.backgroundColor; 
this.style.backgroundColor- '# eeeeee'"); 
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gdvNews.Rows[i].Attributes.Add ( "onmouseout", "this.style.backgroundColor 
-c"); 

LinkButton deleteButton =new LinkButton (); 

deleteButton = (LinkButton) gdvNews . Rows [i] .Cells [7] .FindControl 

("lbDelete"); 

deleteButton.Attributes.Add("onclick", "return confirm(' 确 定 要 删除 此 新 闻 
ny"); 


上 面 的 代码 中 使 用 了 NewsClassDB 这 个 类 ,下 面 把 这 个 类 中 的 方法 展示 ,在 本 系统 中 
还 有 好 多 类 的 定义 ,这 里 就 不 一 一 列 出 ,请 读者 参阅 源 代码 。 


using System.Data.SqlClient; 


using NewsManage.Model; 


namespace NewsManage.DAL 


t 


/// < summary» 
///NewsClassDB 的 摘要 说 明 
/// < /summary» 


public class NewsClassDB 


t 


/// «summary» 
/// 新 增 类 别 数据 
/// </summary> 
/// «param name= "className"> 类 别名 称 </param> 
/// «param name= "classDescription"> 类 别 描述 < /param» 
/// «param name= "classOrder"> 类 别 顺 序 < /param> 
/// «param name= "itemID"> 所 属 栏目 ID< /param> 
/// <returns> 是 否 成 功 < /returns> 
public static bool AddClass (string className, string classDescription, int classOrder, 
int itemID) 
t 
using (SqlConnection connection = new SqlConnection ( DBConnection. 
ConnectString)) 
t 
SqlCormand command - new SqlCommand ("insert into t class values 
(&classname, 6classdesc, 6€classorder, (itemid)", connection); 
connection.Open (); 
command. Parameters.Add ("Gclassname", SqlDbType.VarChar, 50); 
command. Parameters.Add("éclassdesc", SqlDbType.VarChar, 200); 
command. Parameters .Add ("éclassorder", SqlDbType.Int); 
command.Parameters.Add("(itemid", SqlDbType.Int); 
command.Parameters[0].Value —-className; 
command. Parameters [1].Value —-classDescription; 
command.Parameters[2].Value —-classOrder; 
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command.Parameters [3] .Value = itemID; 

int effectiveRows = command.ExecuteNonQuery () ; 
if (effectiveRows » 0) 

{ 


return True; 


return False; 


} 
/// < sumary> 
/1/ 得 到 所 有 类 别 
/// < /sumnary» 
/// <returns> 类 别 列表 < /returns» 
public static IList< NewsClass> GetAll () 
{ 
IList< NewsClass>newsClassList =new List< NewsClass> (); 
using ( SqlConnection connection = new SqlConnection ( DBConnection. 
ConnectString)) 
t 
SqlCommand command = new SqlCommand ("select * from t class order by itemid, 
classorder,classid", connection); 
connection.Open () ; 
SqlDataReader classReader - command.ExecuteReader () ; 
while (classReader.Read()) 
{ 
NewsClass newsClass =new NewsClass(); 
newsClass —FillData (classReader); 
newsClassList.Add (newsClass); 


H 
return newsClassList; 
H 
/// « summary» 
/// 得 到 栏目 下 所 有 类 别 
/// < /summary> 
/// «param name- "itemID"> 栏 目 ID< /param> 
/// <returns> 类 别 列表 < /returns> 
public static IList< NewsClass> GetItemClass (int itemID) 
t 
IList«NewsClass» newsClassList =new List« NewsClass» (); 


using (SqglConnection connection =new SqlConnection (DBConnection.ConnectString)) 


} 


SqlCommand command =new SqlCommand ("select * from t class where itemid- @ 


itemid order by itemid,classorder,classid", connection); 


connection.Open(); 
command. Parameters .Add ("@itemid", SqlDbType.Int); 
command.Parameters [0] .Value —itemID; 
SqlDataReader classReader = command.ExecuteReader () ; 
while (classReader.Read()) 
t 

NewsClass newsClass —new NewsClass(); 

newsClass —FillData (classReader); 


newsClassList.Add (newsClass); 


return newsClassList; 


) 


/// «summary» 

/// 得 到 所 有 的 类 别 以 及 所 对 应 的 栏目 名 称 

/// </summary> 

/// <returns> 类 别 栏目 对 象 集合 < /returns> 

public static IList« NewsClassItem» GetClassItemName () 


t 


IList«NewsClassItem» newsClassItemList —new List« NewsClassItem» (); 


using ( SqlConnection connection 


new SqlConnection ( DBConnection. 


ConnectString)) 


t 


SqlCommand command = new SqlCommand (" select a. classid, a. classname, a. 
classdesc,a.classorder, b.itemid, b.itemname, b.itemdesc,b.itemorder from t - 
Class a,t Item b where a.itemid-b.itemid order by classid", connection); 
connection.Open(); 
using (SqlDataReader classItemReader = command.ExecuteReader () ) 
t 
while (classItemReader.Read|()) 
{ 
NewsClassItem newsClassItem =new NewsClassItem(); 
newsClassItem.ClassID —- classItemReader.GetInt32 
(classItemReader.GetOrdinal ("classid")); 
newsClassItem.ClassName —classItemReader.GetString 
(classItemReader.GetOrdinal ("classname")); 
newsClassItem.ClassDescription -classItemReader.GetString 
(classItemReader.GetOrdinal ("classdesc")); 
newsClassItem.ClassOrder —-classItemReader.GetInt32 
(classItemReader.GetOrdinal ("classorder")); 
newsClassItem.ItemID —classItemReader.GetInt32 
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(classItemReader.GetOrdinal ("itemid")); 
newsClassItem.ItemName —classItemReader.GetString 
(classItemReader.GetOrdinal ("itemname")); 
newsClassItem.ItemDescription - classItemReader.GetString 
(classItemReader.GetOrdinal ("itemdesc")); 
newsClassItem.ItemOrder — classItemReader.GetInt32 
(classItemReader.GetOrdinal ("itemorder")); 
newsClassItemList.Add (newsClassItem); 


} 


return newsClassItemList; 


} 
/// < summary> 
/// 得 到 管理 员 所 管辖 的 类 别 列表 
/// </summary> 
AA 
/// «returns» 2E J| 9l] & « /returns» 
public static IList« NewsClass» GetListByUser (int userID) 
t 
IList«NewsClass» newsClassList =new List« NewsClass» (); 
using (SqlConnection connection - new SqlConnection (DBConnection.ConnectString)) 
t 
SqlCommand command = new SqlCommand ("select a. * from t class a,t popedom b 
where a.classid-b.classid and b.userid- (userid order by itemid, classorder, 
classid", connection); 
connection.Open(); 
command. Parameters .Add ("@userid", SqlDbType.Int); 
command. Parameters [0] .Value =userID; 
SqlDataReader classReader - command.ExecuteReader () ; 
while (classReader.Read|()) 
t 
NewsClass newsClass - new NewsClass(); 
newsClass —FillData (classReader); 


newsClassList.Add (newsClass); 


H 
return newsClassList; 
H 
/// «summary» 
/// 删除 类 别 
///</summary> 
/// «param name- "classID"> 类 别 ID< /param> 
public static void DeleteClass (int classID) 
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using (SqglConnection connection =new SqlConnection (DBConnection.ConnectString)) 
t 
connection.Open(); 
SqlCommand commandSelect - new SqlCommand ("select count(* ) from 
t news where classid-6classid", connection); 
commandSelect.Parameters.Add("Gclassid", SqlDbType.Int); 
commandSelect.Parameters[0].Value —classID; 
SqlCommand commandDelete =new SqlCommand ("delete from t class where classid- 
Qclassid", connection); 
commandDelete.Parameters.Add("Gclassid", SqlDbType.Int); 


commandDelete.Parameters[0].Value —classID; 


int selectRows - Convert .ToInt32 (commandSelect .ExecuteScalar () ) ; 
if (selectRows » 0) 
t 
HttpContext .Current .Response.Write ("< script» alert (" 该 类 别 下 有 文章 数据 ,不 能 删 
BR 1 *) :10cation.replace (window. locaticn.href) ;« /script» ") ; 
) 
else 
{ 
int deleteRows =commandDelete.ExecuteNonQuery () ; 
if (deleteRows » 0) 
t 
/ BttpContext .Current . Response .Write ("< script» alert (' 删 除 成 功 !'); 
</script>"); 
} 
else 
{ 
HttpContext.Current.Response.Write ("< script» alert(' 删 除 失 败 , 请 稍 
后 重 试 !1');< /script» "); 


} 

/// < summary» 

/// 更 新 类 别 

/// < /summary> 

/// «param name- "classID"> 类 别 ID< /param> 

/// «param name= "className"> 类 别名 称 < /param> 

/// «param name- "classDescription"> 类 别 描述 < /param> 

/// «param name= "classOrder"> 类 别 顺序 < /param> 

/// «param name= "itemID"> 所 属 栏 目 ID< /param> 

public static void UpdateClass (int classID, string className, string classDescription, 
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int classOrder, int itemID) 
t 
using (SqlConnection connection - new SqlConnection (DBConnection.ConnectString)) 
t 
SqlCommand commandUpdate = new SqlCommand ("update t class set classname- @ 
classname, classdesc- 6 classdesc, classorder- @ classorder, itemid- 8 itemid where 
classid- 6classid", connection); 
connection.Open(); 
commandUpdate.Parameters.Add("Gclassid", SqlDbType.Int); 
coamandopdate. Parameters .Add ("éclassname", SqiDblype.VarChar, 50); 
conmandUpdate. Parameters .Add("éclassdesc", SqlDbType .VarChar, 200); 
commandUpdate . Parameters .Add ("6classorder", SglDbType.Int); 
commandUpdate. Parameters .Add ("@itemid", SqlDbType.Int); 
commandUpdate . Parameters [0] .Value - classID; 
commandUpdate . Parameters [1] .Value - className; 
commandUpdate. Parameters [2] .Value 7 classDescription; 
commandUpdate . Parameters [3] .Value - classOrder; 


commandUpdate. Parameters [4] .Value — itemID; 


int updateRows = commandUpdate .ExecuteNonQuery () ; 

if (updateRows » 0) 

{ 
HttpContext.Current.Response.Write ("< script» alert (' 更 新 成 功 !');</ 
script»"); 

) 

else 

{ 
HttpContext.Current.Response.Write("« script» alert (' 更 新 失败 ,请 稍 后 重 
ik 1');« /script» "); 


} 

private static NewsClass FillData (IDataReader classReader) 

{ 
NewsClass newsClass =new NewsClass (); 
newsClass.ClassID =classReader.GetInt32 (classReader .GetOrdinal 
("classid")); 
newsClass.ClassName = classReader.GetString (classReader.GetOrdinal 
("classname")); 
newsClass.ClassDescription —classReader.GetString (classReader.GetOrdinal 
("classdesc")); 
newsClass.ClassOrder - classReader.GetInt32 (classReader.GetOrdinal 
("classorder")); 


newsClass.ItemID —classReader.GetInt32 (classReader.GetOrdinal 


("itemid")); 


return newsClass; 
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